0

0

C++如何与Lua交互?C++嵌入Lua脚本引擎教程【混合编程】

尼克

尼克

发布时间:2025-12-16 17:08:02

|

847人浏览过

|

来源于php中文网

原创

C++嵌入Lua核心是纯C API操作栈:初始化状态机并加载脚本;C++调用Lua函数需压参、pcall、取返回值;注册C函数供Lua调用;用userdata封装复杂数据并配元表;全程注意栈平衡。

c++如何与lua交互?c++嵌入lua脚本引擎教程【混合编程】

用C++嵌入Lua,核心是调用Lua C API完成操作、函数调用和数据交换。不依赖第三方绑定库(如sol2或LuaBridge),纯C API方式最轻量、最可控,也最能帮你理解底层交互逻辑。

一、初始化Lua环境并加载脚本

先链接lua5.4.lib(或对应版本)并包含头文件lua.hpp(或分开包含lua.hlauxlib.hlualib.h)。创建Lua状态机是第一步:

  • 调用luaL_newstate()获得lua_State*指针,这是整个Lua世界的入口
  • luaL_openlibs(L)加载标准库printstringtable等才可用)
  • 加载脚本有三种常用方式:luaL_dostring(L, "print('hello')")(字符串)、luaL_loadfile(L, "main.lua") + lua_pcall(文件)、luaL_loadbuffer(内存块)

二、C++调用Lua函数

前提是Lua函数已存在(全局或放在table里),调用过程本质是“压参→调用→取返回值”,全程操作Lua栈:

  • lua_getglobal(L, "add")把全局函数add压入栈顶
  • lua_pushnumber(L, 10)lua_pushnumber(L, 20)依次压入参数(顺序即调用顺序)
  • 调用lua_pcall(L, 2, 1, 0):2个参数、期望1个返回值、无错误处理函数
  • 调用后栈顶是返回值,用lua_isnumber(L, -1)判断类型,再用lua_tonumber(L, -1)取出,最后lua_pop(L, 1)清理

三、Lua调用C++函数(注册C函数)

让Lua能直接调用C++逻辑,需把C函数注册为Lua全局函数或table成员。注意:C函数签名固定为int func(lua_State* L),返回值是“推入栈的返回值个数”:

Heeyo
Heeyo

Heeyo:AI儿童启蒙陪伴师,风靡于硅谷的儿童AI导师和玩伴

下载

立即学习C++免费学习笔记(深入)”;

  • 写一个C风格函数,例如int l_print_time(lua_State* L) { time_t t = time(nullptr); lua_pushnumber(L, (double)t); return 1; }
  • 注册到全局:lua_register(L, "os_time", l_print_time),之后Lua中就能写print(os_time())
  • 若想注册进table(如mylib),先创建table(lua_newtable(L)),再用lua_pushcfunction+lua_setfield设字段

四、在C++和Lua间传递复杂数据(table、string、userdata)

基础类型(number/string/boolean)直接用lua_pushxxx/lua_toxxx;结构体或对象建议用userdata封装,配合元表实现面向对象风格:

  • 创建userdata:MyClass* obj = (MyClass*)lua_newuserdata(L, sizeof(MyClass)); new(obj) MyClass();
  • 设置元表(定义__index__gc等):luaL_newmetatable(L, "MyClass"); lua_setmetatable(L, -2);
  • 从Lua读取table字段:先lua_getfield(L, -1, "name"),再lua_tostring,记得lua_pop清理栈
  • 向Lua返回table:用lua_createtable(L, 0, 2),然后lua_pushstring+lua_setfield键值对

基本上就这些。栈平衡是关键——每次push要配对pop,函数调用前后栈深差应等于参数个数减返回个数。多练几个小例子(比如传数组、调用带callback的C函数),很快就能上手。

相关专题

更多
python中print函数的用法
python中print函数的用法

python中print函数的语法是“print(value1, value2, ..., sep=' ', end=' ', file=sys.stdout, flush=False)”。本专题为大家提供print相关的文章、下载、课程内容,供大家免费下载体验。

185

2023.09.27

string转int
string转int

在编程中,我们经常会遇到需要将字符串(str)转换为整数(int)的情况。这可能是因为我们需要对字符串进行数值计算,或者需要将用户输入的字符串转换为整数进行处理。php中文网给大家带来了相关的教程以及文章,欢迎大家前来学习阅读。

318

2023.08.02

java中boolean的用法
java中boolean的用法

在Java中,boolean是一种基本数据类型,它只有两个可能的值:true和false。boolean类型经常用于条件测试,比如进行比较或者检查某个条件是否满足。想了解更多java中boolean的相关内容,可以阅读本专题下面的文章。

350

2023.11.13

java boolean类型
java boolean类型

本专题整合了java中boolean类型相关教程,阅读专题下面的文章了解更多详细内容。

27

2025.11.30

go语言 面向对象
go语言 面向对象

本专题整合了go语言面向对象相关内容,阅读专题下面的文章了解更多详细内容。

56

2025.09.05

java面向对象
java面向对象

本专题整合了java面向对象相关内容,阅读专题下面的文章了解更多详细内容。

50

2025.11.27

js 字符串转数组
js 字符串转数组

js字符串转数组的方法:1、使用“split()”方法;2、使用“Array.from()”方法;3、使用for循环遍历;4、使用“Array.split()”方法。本专题为大家提供js字符串转数组的相关的文章、下载、课程内容,供大家免费下载体验。

258

2023.08.03

js截取字符串的方法
js截取字符串的方法

js截取字符串的方法有substring()方法、substr()方法、slice()方法、split()方法和slice()方法。本专题为大家提供字符串相关的文章、下载、课程内容,供大家免费下载体验。

209

2023.09.04

PS使用蒙版相关教程
PS使用蒙版相关教程

本专题整合了ps使用蒙版相关教程,阅读专题下面的文章了解更多详细内容。

23

2026.01.19

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
国外Web开发全栈课程全集
国外Web开发全栈课程全集

共12课时 | 1.0万人学习

进程与SOCKET
进程与SOCKET

共6课时 | 0.3万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号