获取Lua表结构(table)数据实例_Lua

只是获取一个全局变量什么的太没意思了,今天我们来玩个高难度的——获取Lua表结构的数据。
(旁白:O O!我是不是该说点什么?)

上一章传送门:http://www.jb51.net/article/55093.htm

1. 什么是table

table是Lua里最强大的数据类型,我们可以当成是数组,但是它又和数组有点不一样,建议大家看看Lua的语法教程,因为我对table也没有熟悉到可以给大家解释的程度。
(旁白:那你还写什么教程。。。)

2. 获取table变量

现在,我们给helloLua.lua文件添加一个table全局变量:

复制代码 代码如下:

-- helloLua.lua文件
myName = "beauty girl"

helloTable = {name = "mutou", IQ = 125}

我们看到,多了一个helloTable的变量,它和数组十分相似,又和HashMap有点类似,总之它很强大。

(旁白:我觉得亮点是,你的IQ有125?我觉得乘以2的话,还有点可能~!)
话说,125乘以2等于多少?…250 ….O O!
获取helloTable变量的方式和以前是一样的:

复制代码 代码如下:

/* 取得table变量,在栈顶 */
    lua_getglobal(pL, "helloTable");

这样,helloTable变量就被存放到栈顶。
可我们并不是要取table变量,因为C++中是无法识别Lua的table类型的,所以我们要取得table中具体的值,也就是name和IQ的值。

3. lua_gettable函数

有一个和lua_getglobal类似的函数,叫做lua_gettable,顾名思义,它是用来取得table相关的数据的。
(旁白:废话少点好吧= =)
 
lua_gettable函数会从栈顶取得一个值,然后根据这个值去table中寻找对应的值,最后把找到的值放到栈顶。
lua_pushstring()函数可以把C++中的字符串存放到Lua的栈里;
然后再用lua_gettable()取执行前面所说的步骤,lua_gettable的第二个参数是指定的table变量在栈中的索引。
(旁白:小笨木,我被你绕晕了。。。)
 
为了照顾旁白这个笨蛋,我们画个图来理解:

这是初始状态,堆栈里还没有任何东西,那么,现在要先把helloTable变量放到栈顶:

复制代码 代码如下:

/* 取得table变量,在栈顶 */
    lua_getglobal(pL, "helloTable");

然后就变成了这样:

接着,我们要取得table的name对应的值,那么,先要做的就是把”name”字符串入栈:

复制代码 代码如下:

/* 将C++的字符串放到Lua的栈中,此时,栈顶变为“name”, helloTable对象变为栈底 */
    lua_pushstring(pL, "name");

然后变成这样:

(旁白:不带这样啊,你偷偷加上了栈的索引~!)
 
注意了,我把栈的索引也加上了,因为我们即将要使用,这次我们用负数索引(不了解负数的索引的朋友请阅读第03章的教程哈~)。
由于”name”的入栈,现在helloTable变量已经不在栈顶了。
接着,我们调用要做最重要的一步了,取得name在table中对应的值:

复制代码 代码如下:

/*
        从table对象寻找“name”对应的值(table对象现在在索引为-2的栈中,也就是当前的栈底),
        取得对应值之后,将值放回栈顶
    */
    lua_gettable(pL, -2);

此时,栈变成这样:

(旁白:发生什么事?为什么“mutou”突然出现在栈顶?!为毛!是你自己画上去的吧!)
 
lua_gettable倒底做了什么事情?
首先,我们来解释一下lua_gettable的第二个参数,-2是什么意思,-2就是刚刚helloTable变量在栈中的索引。
然后,Lua会去取得栈顶的值(之前的栈顶是”name”),然后拿着这个值去helloTable变量中寻找对应的值,当然就找到”mutou”了。
最后,Lua会把找到的值入栈,于是”mutou”就到了栈顶了。
(旁白:你妹纸的。。。没事,我就骂骂人)
 
最后我们只需要取出栈顶的数据就可以了,完整代码如下:

复制代码 代码如下:

/* 初始化 */
    lua_State* pL = lua_open();
    luaopen_base(pL);

    /* 执行脚本 */
    luaL_dofile(pL, "helloLua.lua");

    /* 取得table变量,在栈顶 */
    lua_getglobal(pL, "helloTable");

    /* 将C++的字符串放到Lua的栈中,此时,栈顶变为“name”, helloTable对象变为栈底 */
    lua_pushstring(pL, "name");

    /*
        从table对象寻找“name”对应的值(table对象现在在索引为-2的栈中,也就是当前的栈底),
        取得对应值之后,将值放回栈顶
    */
    lua_gettable(pL, -2);

    /* 现在表的name对应的值已经在栈顶了,直接取出即可 */
    const char* sName = lua_tostring(pL, -1);
    CCLOG("name = %s", sName);

好了,本章到此结束。

时间: 2024-09-19 09:12:41

获取Lua表结构(table)数据实例_Lua的相关文章

mysql 复制表结构和数据实例代码_Mysql

在mysql数据库开发中,我们有时候需要复制或拷贝一张表结构和数据到例外一张表,这个时候我们可以使用create ... select ... from语句来实现,本文章向大家介绍mysql复制表结构和数据一个简单实例,  比如现在有一张表,我们要将该表复制一份,以备以后使用,那么如何使用mysql语句来实现呢?其实我们可以直接使用create ... select ... from语句来实现,具体实现方法请看下面实例.  我们先来创建一张Topic表,创建Topic表的SQL语句如下: mys

Lua中对table排序实例_Lua

lua中利用到的排序的基本上就是构造函数(table)了,为了便于和C区分开来,我俗称它为表单. 实例:(原理就是LUA集成的冒泡算法) 排序的一般姿势(对于只包含数字或者只包含字符串的简单数组) 复制代码 代码如下: table.sort(test) 扩展版 复制代码 代码如下: table.sort(test, function(a,b) return a.id<b.id end ) 实例一:值排序 1.数组模式 复制代码 代码如下: local test0 ={1,9,2,8,3,7,4,

Oracle数据库向MS Sql表结构及数据如何迁移?

问题描述 新来的经理三把火了,要我们把数据库改了,可是我们没有数据库迁移的经验,网上的博客都是模棱两可的.请教下各位大牛.Oracle数据库向MS Sql2000表结构及数据如何迁移?我们使用了DTS但是提示"未知错误",就不得不中断,请问数据库迁移还有别的办法吗?或者这种未知错误有解? 解决方案 参考http://www.sql-server-performance.com/2003/migrating-from-oracle-to-sql-server/我其实为吐槽来的.Oracl

js获取form表单所有数据的简单方法_javascript技巧

在HTML中用js获取通过GET.POST方法(就是在网址后加?a=b&c=d之类)传过来的表单值. 针对大家常用的获取表单方式,很多时候都是在重复的写一些代码,今天给大家贴出来的代码可以作为公用方法直接调用.可以提高大家的开发效率. Js代码 <script type="text/javascript"> //获取指定form中的所有的<input>对象 function getElements(formId) { var form = documen

sql server-不同数据库,不同表结构之间数据迁移

问题描述 不同数据库,不同表结构之间数据迁移 现在新旧系统切换,需要在新库中把老库的一些表数据导入到新库,但是新库的表结构是经过优化的,导致了新.老库表结构不一样的情况,请教一个迁移方案,谢谢(老库是sqlserver,新库是mysql) 解决方案 不同数据库表之间表数据复制不同数据库之间复制表的数据的方法:不同数据库之间复制表的数据的方法 解决方案二: 不同数据库表之间表数据复制不同数据库之间复制表的数据的方法:不同数据库之间复制表的数据的方法 解决方案三: 你数据库表的结构都有改变了.一般是

php接收表单提交数据实例详解

PHP $_GET 和 $_POST变量是用来获取表单中的信息的,比如用户输入的信息 PHP4.1(好像)以后取消了直接接收变量,而用 $_GET['变量名'] 接收从链接传递过来的变量, 用 $_POST['变量名'] 接收从表单提交来的变量.同样有$_FILES[],$_SERVER[]等 下面是一个 HTML 文件,这个 HTML 含有一个 HTML 表单 (HTML Form),主要用来让用户输入用户姓名的.  代码如下 复制代码 <form action ="get.php&qu

Lua编程示例(五): C语言对Lua表的读取和添加_Lua

#include "stdafx.h" lua_State *L; void load_lua(char *filename){ L=luaL_newstate(); luaL_openlibs(L); if((luaL_loadfile(L,filename) || lua_pcall(L,0,0,0))!= 0){ luaL_error(L,"loadfile error! \n %s",lua_tostring(L,-1)); } } double getfi

mysql在线修改表结构大数据表的风险与解决办法归纳

整理这篇文章的缘由: 互联网应用会频繁加功能,修改需求.那么表结构也会经常修改,加字段,加索引.在线直接在生产环境的表中修改表结构,对用户使用网站是有影响. 以前我一直为这个问题头痛.当然那个时候不需要我来考虑,虽然我们没专门的dba,他们数据量比我们更大,那这种问题也会存在.所以我很想看看业界是怎么做的,我想寻找有没有更高级的方案,呵呵,让我觉得每次开发一个新功能,我在线加字段都比较纠结.后来只知道,不清楚在什么时候,无意中看到一个资料介绍online-schema-change这个工具,于是

oracle、mysql、sybase和sqlserver复制表结构和数据

Sql Server(sybase): 1.复制表结构: 新建表student2,并且结构同表syn_xj_student一致.Sql语句如下: select * into syn_xj_student2 from syn_xj_student where 1=2 2.复制表数据,并排除俩表中相同的数据: insert into syn_xj_student2 select * from syn_xj_student where f_id not in (select f_id from syn