记一次C++与lua连接
今晚,花了两个多钟折腾lua和c++的互连,终于成功了,觉得有必要记录下来。说实话,搜索引擎真是有利有弊,利在你有地方搜答案,弊则在于你半天都找不到正确的答案甚至找到误导你的答案,今晚更加加深了我的体会,不过总算折腾出点成果了。
前期准备:装好LuaForWindows(LFW),装好Visual Studio 2013(其实用6.0就已经足够了)。
接下来,打开VS,新建一个解决方案,在解决方案下新添加一个工程,作为我的第一个例子,就新建了一个win32控制台程序。然后,右键工程设置它的属性:
配置属性->VC++目录->可执行文件目录,设置LFW目录,例:E:\Program\lua\5.1
配置属性->VC++目录->包含目录,设置include文件夹,例:E:\Program\lua\5.1\include
配置属性->VC++目录->库目录-设置lib目录,例:E:\Program\lua\5.1\lib
链接器->输入->附加依赖项,添加“lua5.1.lib;lua51.lib”
接下来,送上C++代码了,在网上东拼西凑,再加点自己代码的混合体:
- // Test.cpp : 定义控制台应用程序的入口点。
- //
- // Lua和C通过一堆栈struct lua_State交换数据,栈底为1,栈顶为-1,默认大小20
- // lua_checkstack : 修改栈大小
- // lua_gettop : 获得栈元素数目
- // lua_getglobal : 获取某全局变量,void lua_getglobal(lua_State*L, constchar*name)
- // lua_isnumber/ lua_istable : 判断类型
- // lua_tonumber/ lua_tostring : 类型转换
- // lua_pushstring : 压入栈顶,如lua_pushstring(L, "i")
- // lua_pushnil : 压入一空值
- // lua_remove : 从栈移除元素
- // lua_gettable :
- // lua_next : 遍历数组(key从1开始的table),如while(lua_next(L, -2)!=0){}
- //
- // lua_newtable(L) - 新建table放在栈顶
- // lua_pushstring(L,"mydata") - 压入key
- // lua_pushnumber(L,66) - 压入value
- // lua_settable(L, -3)
- // lua_rawseti(L, -2, 0)
- // ...
- //
- // 调用Lua函数可以这样理解吧,压入函数->压入参数->call->返回值已经在栈顶。不知道对不对
- //
- #include "stdafx.h"
- #include "stdlib.h"
- extern "C"{
- #include "lua.h"
- #include "lualib.h"
- #include "lauxlib.h"
- };
- lua_State *L;
- int luaAdd(int x, int y)
- {
- int sum;
- lua_getglobal(L, "add"); //Lua函数也是变量(指针),可入栈
- lua_pushnumber(L, x); //参数入栈
- lua_pushnumber(L, y); //参数入栈
- lua_call(L, , );
- sum = (int)lua_tonumber(L, -);
- lua_pop(L, );
- return sum;
- }
- int _tmain(int argc, _TCHAR* argv[])
- {
- int sum = ;
- L = lua_open(); //创建Lua接口指针
- luaopen_base(L); //加载Lua基本库
- luaL_openlibs(L); //加载Lua通用扩展库
- luaL_loadfile(L, "add.lua"); //加载脚本
- lua_pcall(L, , LUA_MULTRET, ); //调用Lua函数,pcall函数会自动清除入栈变量(虚拟机指针,,,)
- sum = luaAdd(, );
- printf("The sum is %d\n", sum);
- lua_close(L);
- system("PAUSE");
- return ;
- }
还有add.lua脚本:
- --简单的例子,只做整数加法
- function add(x, y)
- return x + y
- end
脚本保存在工程目录下,和cpp文件住在一起。
总算看到控制台的显示“The sum is 25”了,虽说,整个过程写出来好像很简单的样子,但折腾一下就知道探索的过程有多辛苦了!
记一次C++与lua连接的更多相关文章
- lua连接redis集群
连接redis集群需要用到llua-resty-redis-cluster模块 github地址:https://github.com/cuiweixie/lua-resty-redis-cluste ...
- 随记PC-win7 64位系统网络连接状态一直转圈、等待状态的异常解决方案
各位看官好~ 最近电脑也做了下升级,入手个士必得360G的SSD来玩玩,顺便也下个新系统,看看有什么区别,想想顺便升级下系统也是好的,就开始了装机,装系统的路程~~~~~~ 好了不说废话,直接进入主题 ...
- 架构师养成记--22.客户端与服务器端保持连接的解决方案,netty的ReadTimeoutHandler
概述 保持客户端与服务器端连接的方案常用的有3种 1.长连接,也就是客户端与服务器端一直保持连接,适用于客户端比较少的情况. 2.定时段连接,比如在某一天的凌晨建立连接,适用于对实时性要求不高的情况. ...
- 记一次Docker中Redis连接暴增的问题排查
周六生产服务器出现redis服务器不可用状态,错误信息为: 状态不可用,等待后台检查程序恢复方可使用.Unexpected end of stream; expected type 'Status' ...
- 记一次MacBook Pro无法连接wifi网络修复
解决方案: https://blog.csdn.net/kimbing/article/details/79321001 真的哭了 原因是插入了我的USB3.0拓展坞影响了wifi信号 不知道原理是啥 ...
- Lua笔记(1)
今天开始学习Lua,下面把一些重点记下来: 单行注释-- ,多行注释 --[[ ....... --]] Lua中false和nil表示条件判断的假,其余的,包括空字符串,0,都表示真. Lua没 ...
- 我和Lua并非一见钟情,我们期待着日久生情(相遇篇)
Lua作为一款轻量级的脚本语言,由标准C编写而成,可被C/C++调用,也可调用C/C++的函数. 在目前的脚本引擎中,Lua的速度是最快的... Lua可直接在EditPlus文本处理器上开发,只需搭 ...
- Linux 下 Lua 与 LuaSQL 模块安装
相关说明: Lua最近在Nginx的web服务器上挺火的, 它的高效让更多开发喜欢上它, 本文讲述Lua与LuaSQL的安装. 在上几篇mysql-proxy的安装中有提到和操作过. 操作系统: Li ...
- Lua 数据库访问(转)
本文主要为大家介绍 Lua 数据库的操作库:LuaSQL.他是开源的,支持的数据库有:ODBC, ADO, Oracle, MySQL, SQLite 和 PostgreSQL. 本文为大家介绍MyS ...
随机推荐
- CSS3 布局
1.1 列布局 CSS3中新出现的多列布局(multi-column)是传统HTML网页中块状布局模式的有力扩充.这种新语法能够让WEB开发人员轻松的让文本呈现多列显示.我们知道,当一行文字太长时 ...
- Asp.Net实现Http长连接推送
话说最新帮一个朋友搞智能家居方面的东西,做一个云平台.主要作用手机在局域网外环境时对手机客户端和智能网关中命令的互相转发. 目前已经有了一个稳定的Socket版本,但是考虑到以后的扩展和性能指标要改成 ...
- C++写geohash
http://www.cnblogs.com/LBSer/p/3310455.html http://www.sxrczx.com/pages/my.oschina.net/853294317/blo ...
- HDU 1045(Fire Net)题解
以防万一,题目原文和链接均附在文末.那么先是题目分析: [一句话题意] 给定大小的棋盘中部分格子存在可以阻止互相攻击的墙,问棋盘中可以放置最多多少个可以横纵攻击炮塔. [题目分析] 这题本来在搜索专题 ...
- MySQL必知必会笔记<2>
[英]ben Forta著 5 1.0 *使用扩展查询* |---->select note from table where Match(note) Against('anl'); |- ...
- Git 详细命令集
初始化一个Git仓库,使用git init命令. 添加文件到Git仓库,分两步: 第一步,使用命令git add <file>,注意,可反复多次使用,添加多个文件: 第二步,使用命令git ...
- hdu 5446 Unknown Treasure 中国剩余定理+lucas
题目链接 求C(n, m)%p的值, n, m<=1e18, p = p1*p2*...pk. pi是质数. 先求出C(n, m)%pi的值, 然后这就是一个同余的式子. 用中国剩余定理求解. ...
- WCF 启用multipleSiteBindingsEnabled 情况下报终结点地址错误
报错信息如下: Server Error in '/MyWcfService' Application. When 'system.serviceModel/serviceHostingEnviron ...
- Spring与Hibernate两种组合方式
第一种 1.hibernate.cfg.xml文件 xml version='1.0' encoding='utf-8'?> "-//Hibernate/Hibernate Confi ...
- Android 使用PopupWindow实现弹出菜单
在本文当中,我将会与大家分享一个封装了PopupWindow实现弹出菜单的类,并说明它的实现与使用. 因对界面的需求,android原生的弹出菜单已不能满足我们的需求,自定义菜单成了我们的唯一选择,在 ...