7

我的宿主C应用程序嵌入了 Lua 解释器,需要通知运行 Lua 脚本中的某些对象/表被垃圾收集,所以它会做一些事情,比如将此事件记录到日志文件。我怎样才能做到这一点?

4

1 回答 1

12

通过向用户数据添加元表并向元表添加“__gc”函数。

在 Lua 5.1 中,只有 userdata 支持“__gc”方法。

检测 Lua 表的垃圾收集的一种方法是在该表中添加一个 canary userdata 对象:

function create_canary(tab)
  local canary=newproxy(true)
  local meta=getmetatable(canary)
  meta.__gc = function() print("Canary is died:", tab) end
  tab[canary] = canary
end

用于创建元表并将其添加到 userdata 对象的 C 代码:

static int userdata_gc_method(lua_State *L) {
  UserObj *ud = lua_touserdata(L, 1);
  /* TODO: do something */
  return 0;
}
static int create_userdata_obj(lua_State *L) {
  UserObj *ud = lua_newuserdata(L, sizeof(UserObj));
  /* TODO: initialize your userdata object here. */

  lua_newtable(L); /* create metatable. */
  lua_pushliteral(L, "__gc"); /* push key '__gc' */
  lua_pushcfunction(L, userdata_gc_method); /* push gc method. */
  lua_rawset(L, -3);    /* metatable['__gc'] = userdata_gc_method */
  lua_setmetatable(L, -2); /* set the userdata's metatable. */
  return 1; /* returning only the userdata object. */
}
于 2010-11-03T19:10:19.087 回答