我想用Lua C API创建一个简单的嵌套表。表中充满了mysql结果。但是,当我尝试读取表格时,我的应用程序崩溃了。
码:
int i = 0;
lua_newtable(L);
while(row = mysql_fetch_row(result))
{
lua_newtable(L);
lua_pushliteral(L, "event");
lua_pushnumber(L, atoi(row[0]));
lua_pushliteral(L, "timestamp");
lua_pushnumber(L, atoi(row[1]));
lua_settable(L, -5);
lua_rawseti(L, -2, ++i);
}
上面应该产生一个Lua表:
{
{event = 1, timestamp = 1234567890},
{event = 2, timestamp = 1234567890},
{event = 2, timestamp = 1234567890},
[..]
}
GDB回溯代码段:
(gdb) bt
#0 luaH_getnum (t=0x3c7db040, key=1) at ltable.c:444
#1 0x0825f94e in luaH_setnum (L=0x3c7d5ca0, t=0x3c7db040, key=1) at ltable.c:500
#2 0x08257fd5 in lua_rawseti (L=0x3c7d5ca0, idx=-2, n=1) at lapi.c:593
怎么了
最佳答案
您的代码仅调用lua_settable
一次,但是您想将"event"
和"timestamp"
都添加到表中:
int i = 0;
lua_newtable(L);
while(row = mysql_fetch_row(result))
{
lua_newtable(L);
lua_pushliteral(L, "event");
lua_pushnumber(L, atoi(row[0]));
lua_settable(L, -3); //Set event
lua_pushliteral(L, "timestamp");
lua_pushnumber(L, atoi(row[1]));
lua_settable(L, -3); //changed `-5` to `-3`
lua_rawseti(L, -2, ++i);
}
您可以使用
lua_setfield
简化代码:int i = 0;
lua_newtable(L);
while(row = mysql_fetch_row(result))
{
lua_newtable(L);
lua_pushnumber(L, atoi(row[0]));
lua_setfield(L,-2,"event");
lua_pushnumber(L, atoi(row[1]));
lua_setfield(L,-2,"timestamp");
lua_rawseti(L, -2, ++i);
}
最后,使用
luaL_checkstack
确保您有足够的工作堆栈:luaL_checkstack(L,3,nullptr);
int i = 0;
lua_newtable(L);
while(row = mysql_fetch_row(result))
{
lua_newtable(L);
lua_pushnumber(L, atoi(row[0]));
lua_setfield(L,-2,"event");
lua_pushnumber(L, atoi(row[1]));
lua_setfield(L,-2,"timestamp");
lua_rawseti(L, -2, ++i);
}