主要内容转载自:子龙山人博客(强烈建议去子龙山人博客完全学习一遍)

部分内容查阅自:《Lua 5.3  参考手册》中文版 译者 云风 制作 Kavcc

vs2013+lua-5.3.3

1.数组

①数组是key值从1开始并连续递增的table。

②索引号是从1开始,不是从0开始。

2.既然是table,那当然是可以用上一节的内容进行读写的。

lua还提供了一些只针对数组进行操作的API,如下:

①LUALIB_API lua_Integer (luaL_len) (lua_State *L, int idx);

使用于数组,可得到数组元素个数;

以数字形式返回给定索引处值的“长度”; 它等价于在 Lua 中调用 '#' 的操作。(非数组使用#将得不到正确的值)

如果操作结果不是一个整数,则抛出一个错误。(这种情况只发生在触发元方法时。)

②LUA_API int (lua_rawgeti) (lua_State *L, int idx, lua_Integer n);

注意对应的lua_rawget函数。

获取索引号n的数组值,返回的int值为值的类型。

这是一次直接访问,不会触发元方法,效率高。

③LUA_API void  (lua_rawseti) (lua_State *L, int idx, lua_Integer n);

注意对应的lua_rawset函数

设置索引号n的数组值。

这个函数会将值弹出栈。 赋值是直接的;即不会触发元方法,效率高。

3.C++读取Lua中数组

①Lua中数组

global_c_read_array = {,6.78,"array string"}

②C++中读取

 //lua->stack,得到全局数组,位置-1
lua_getglobal(L, "global_c_read_array"); //得到数组长度
lua_Integer array_len = luaL_len(L, -);
for (lua_Integer i = ; i <= array_len; ++i){
//lua->stack,全局数组位置-1,然后i为对应的索引值,将返回值放到-1的位置
int ret_type = lua_rawgeti(L, -, i); //--------------被替代的原操作table函数-------------
//lua_pushinteger(L, i);
//int ret_type = lua_gettable(L, -2); //也可以使用int ret_type = lua_rawget(L, -2); //stack->c
if (ret_type == LUA_TNUMBER){
if (lua_isinteger(L, -)){
printf("%lld\n", lua_tointeger(L, -));
}
else if (lua_isnumber(L, -)){
printf("%g\n", lua_tonumber(L, -));
}
}
else if (ret_type == LUA_TSTRING){
printf("%s\n", lua_tostring(L, -));
} lua_pop(L, );
}

4.C++写入Lua数组

①C++写入

 //c->stack,创建一个新的table放到-1的位置
lua_newtable(L); //c->stack,创建对应的key-val
lua_pushinteger(L, ); //设置值
lua_rawseti(L, -, );//对应key-val lua_pushnumber(L, 8.9); //设置值
lua_rawseti(L, -, );//对应key-val lua_pushstring(L, "test_string");//设置值
lua_rawseti(L, -, );//对应key-val //--------------被替代的原操作table函数-------------
//lua_pushinteger(L, 1); //设置key
//lua_pushinteger(L, 7);//设置值
//lua_settable(L, -3); //也可以使用lua_rawset(L,-3); //lua_pushinteger(L, 2); //设置key
//lua_pushnumber(L, 8.9);//设置值
//lua_settable(L, -3); //也可以使用lua_rawset(L,-3); //lua_pushinteger(L, 3); //设置key
//lua_pushstring(L, "test_string");//设置值
//lua_settable(L, -3); //也可以使用lua_rawset(L,-3); //stack->lua,将数组赋值到lua中,并弹出数组
lua_setglobal(L, "global_c_write_array");

②在hello.lua文件中Lua读取

 if global_c_write_array then
for i = , #global_c_write_array do
print("v = ", global_c_write_array[i])
end
end

Lua和C++交互系列:

Lua和C++交互 学习记录之一:C++嵌入脚本

Lua和C++交互 学习记录之二:栈操作

Lua和C++交互 学习记录之三:全局值交互

Lua和C++交互 学习记录之四:全局table交互

Lua和C++交互 学习记录之五:全局数组交互

Lua和C++交互 学习记录之六:全局函数交互

Lua和C++交互 学习记录之七:C++全局函数注册为Lua模块

Lua和C++交互 学习记录之八:C++类注册为Lua模块

Lua和C++交互 学习记录之九:在Lua中以面向对象的方式使用C++注册的类

Lua和C++交互 学习记录之五:全局数组交互的更多相关文章

  1. Lua和C++交互 学习记录之七:C++全局函数注册为Lua模块

    主要内容转载自:子龙山人博客(强烈建议去子龙山人博客完全学习一遍) 部分内容查阅自:<Lua 5.3  参考手册>中文版 译者 云风 制作 Kavcc vs2013+lua-5.3.3 1 ...

  2. Lua和C++交互 学习记录之六:全局函数交互

    主要内容转载自:子龙山人博客(强烈建议去子龙山人博客完全学习一遍) 部分内容查阅自:<Lua 5.3  参考手册>中文版 译者 云风 制作 Kavcc vs2013+lua-5.3.3 1 ...

  3. Lua和C++交互 学习记录之四:全局table交互

    主要内容转载自:子龙山人博客(强烈建议去子龙山人博客完全学习一遍) 部分内容查阅自:<Lua 5.3  参考手册>中文版 译者 云风 制作 Kavcc vs2013+lua-5.3.3 1 ...

  4. Lua和C++交互 学习记录之三:全局值交互

    主要内容转载自:子龙山人博客(强烈建议去子龙山人博客完全学习一遍) 部分内容查阅自:<Lua 5.3  参考手册>中文版 译者 云风 制作 Kavcc vs2013+lua-5.3.3 1 ...

  5. Lua和C++交互 学习记录之九:在Lua中以面向对象的方式使用C++注册的类

    主要内容转载自:子龙山人博客(强烈建议去子龙山人博客完全学习一遍) 部分内容查阅自:<Lua 5.3  参考手册>中文版 译者 云风 制作 Kavcc vs2013+lua-5.3.3 在 ...

  6. Lua和C++交互 学习记录之八:C++类注册为Lua模块

    主要内容转载自:子龙山人博客(强烈建议去子龙山人博客完全学习一遍) 部分内容查阅自:<Lua 5.3  参考手册>中文版 译者 云风 制作 Kavcc vs2013+lua-5.3.3 1 ...

  7. Lua和C++交互 学习记录之二:栈操作

    主要内容转载自:子龙山人博客(强烈建议去子龙山人博客完全学习一遍) 部分内容查阅自:<Lua 5.3  参考手册>中文版 译者 云风 制作 Kavcc vs2013+lua-5.3.3 1 ...

  8. Lua和C++交互 学习记录之一:C++嵌入脚本

    主要内容转载自:子龙山人博客(强烈建议去子龙山人博客完全学习一遍) 部分内容查阅自:<Lua 5.3  参考手册>中文版 译者 云风 制作 Kavcc vs2013+lua-5.3.3 1 ...

  9. SpringMVC学习记录七——sjon数据交互和拦截器

    21       json数据交互 21.1      为什么要进行json数据交互 json数据格式在接口调用中.html页面中较常用,json格式比较简单,解析还比较方便. 比如:webservi ...

随机推荐

  1. P2044 [NOI2012]随机数生成器

    洛咕原题 正常的矩乘题. 但是,计算过程中会爆long long. 所以,我们要用快速(龟速)乘来解决. 快速乘,也就是把快速幂稍作修改.乘法被分成若干个加法,以时间为代价解决精度问题. #inclu ...

  2. DBeaver连接Oracle11g数据库

    DBeaver连接Oracle11g数据库 一.准备 (1)dbeaver管理软件 (2)远程连接数据库地址.用户名秘密等 (3)Oracle驱动:ojdbc6.jar工具包 下载地址:https:/ ...

  3. udp编程 实例

    server端 #include <stdio.h> #include <stdlib.h> #include <unistd.h> #include <er ...

  4. 判断一个点是否在RotatedRect中

    openCV函数pointPolygonTest(): C++: double pointPolygonTest(InputArray contour, Point2f pt, bool measur ...

  5. topcoder srm 445 div1

    problem1 link 这个的结论是只需要考虑坐标是整数或者是整数.5,比如(2.5,3),(4,3.5),(1.5,4.5)这样的时候.这个详细证明起来应该挺麻烦的.这里有一些讨论. probl ...

  6. Python3 tkinter基础 Canvas create_text 在画布上添加文字

             Python : 3.7.0          OS : Ubuntu 18.04.1 LTS         IDE : PyCharm 2018.2.4       Conda ...

  7. Java TreeSet的定制排序

    注:只贴出实现类 package Test3; import java.util.Comparator;import java.util.TreeSet; public class Test { pu ...

  8. noip模拟【array】

    array by ysy [题目描述] 给定一个长度为n的数列,每次你可以进行以下操作之一: (1)将一个数+a: (2)将一个数-a: (3)将一个数+b: (4)将一个数-b: 你需要将所有数全部 ...

  9. POJ 3250 Bad Hair Day【单调栈入门】

    Bad Hair Day Time Limit: 2000MS   Memory Limit: 65536K Total Submissions: 24112   Accepted: 8208 Des ...

  10. SpringBoot 调用 mysql存储过程的实战

    网络上写的一堆都不能用的 好吧.. 首先创建 存储过程 DROP PROCEDURE IF EXISTS dfsSons; CREATE PROCEDURE dfsSons(IN rootid INT ...