在 C 模块中声明向量变量会导致段错误

我正在测试在 Lua(5.1)中调用 C/C++ 模块。如果没有使用向量,则代码能够正常工作。但是,当我在 add 函数中包含 stl/vector 并声明一个向量变量时,程序就会导致段错误。

libvec.so 代码:

#include <vector>
#include <list>
#include "lua.hpp"
#include <algorithm>
#include <iostream>
#include <string>
#include <map>

extern "C" int add(lua_State* L)
{
    double op1 = luaL_checknumber(L, 1);
    double op2 = luaL_checknumber(L, 2);
    //std::vector<double> vec;
    //vec.push_back(op1);
    //vec.push_back(op2);
    //lua_pushnumber(L, vec[0]+vec[1]);
    lua_pushnumber(L, op1 + op2);
    return 1;
}

static luaL_Reg mylibs[] = {
    {"add", add}
};

extern "C" int luaopen_libvec(lua_State *L){
    luaL_register(L, "libvec", mylibs);
    return 1;
}

test.lua 代码:

local vec = require 'libvec'
print(vec.add(1,212))

然后我尝试使用 gdb lua/run test.lua,结果获得如下信息:

strlen () at ../sysdeps/x86_64/strlen.S:106
106 ../sysdeps/x86_64/strlen.S: No such file or directory.
(gdb) bt
#0  strlen () at ../sysdeps/x86_64/strlen.S:106
#1  0x000000000040596e in lua_setfield ()
#2  0x0000000000412f75 in luaL_openlib ()
#3  0x00007ffff6e8e531 in luaopen_libvec () from ./libvec.so
#4  0x00000000004080d8 in luaD_precall ()
#5  0x00000000004084e4 in luaD_call ()
#6  0x0000000000405c95 in lua_call ()
#7  0x000000000041dcaa in ll_require ()
#8  0x00000000004080d8 in luaD_precall ()
#9  0x00000000004116d2 in luaV_execute ()
#10 0x000000000040852d in luaD_call ()
#11 0x000000000040782b in luaD_rawrunprotected ()
#12 0x000000000040868b in luaD_pcall ()
#13 0x0000000000405d26 in lua_pcall ()
#14 0x0000000000403ecc in docall ()
#15 0x00000000004048a9 in pmain ()
#16 0x00000000004080d8 in luaD_precall ()
#17 0x00000000004084e4 in luaD_call ()
#18 0x000000000040782b in luaD_rawrunprotected ()
#19 0x000000000040868b in luaD_pcall ()
#20 0x0000000000405db5 in lua_cpcall ()
#21 0x0000000000403b94 in main ()

当我测试 std:: map 并崩溃时,而 std::string 则能够正常工作...

点赞
用户1548468
用户1548468

luaL_register 的文档中:

任何 luaL_Reg 数组必须以一个哨兵条目结尾,其中 namefunc 均为 NULL

在这里并不是这种情况,我可以想象添加 std::vector 方法以推开先前存在的一些空字节。

tl;dr:在 myLibs 中添加 {NULL, NULL} 条目。

2018-07-31 10:34:15
用户5494370
用户5494370

从文档 https://www.lua.org/manual/5.1/manual.html#luaL_ref 中得知:

用于通过 luaL_register 注册到数组中的函数的类型。name 是函数的名称,func 是一个指向函数的指针。任何 luaL_Reg 数组都必须以 sentinel 条目结尾,其中 name 和 func 均为 NULL。

luaL_register 在数组中迭代,直到找到 sentinel 值为止,如果没有找到,则继续在数组之外进行读取。

正确的数组为:

static luaL_Reg mylibs[] = {
    {"add", add},
    {NULL, NULL}
};
2018-07-31 10:35:24