C/C++: lua_rawget() vs. __index
C/C++ 中调用 Lua 函数时,可以使用 lua_rawget() 或者 __index 来获取 Lua 表中的元素。两者的区别在于,lua_rawget() 直接获取表中的元素,而 __index 则会根据传入的键,查找对应的方法并返回结果。
Lua 的元表可以为表设置元方法。如果使用 __index 来获取表中的元素,就可以使用元表中的 __index 方法了。在元表中,可以使用如下代码来定义 __index 方法:
function mytable.__index(table, key)
return "不存在的元素"
end
在 C/C++ 中,可以使用 luaL_getmetafield() 函数来获取元表中的 __index 方法,如下所示:
int index(lua_State* L) {
lua_getmetatable(L, -2);
lua_pushvalue(L, -2);
lua_rawget(L, -2);
if (lua_isnil(L, -1)) {
// 元素不存在,调用 __index 方法
lua_pop(L, 2);
luaL_getmetafield(L, -1, "__index");
lua_pushvalue(L, -2);
lua_call(L, 2, 1);
}
return 1;
}
需要注意的是,如果元表中同时定义了 __index 和 table[key],那么只会执行 __index 方法。