如果我首先在lua的注册表中放置一些内容:
int ref = luaL_ref(L, LUA_REGISTRYINDEX);
然后使用:
取消引用ref
luaL_unref(L, LUA_REGISTRYINDEX, ref);
并使用以下命令启动垃圾收集器:
lua_gc(L, LUA_GCCOLLECT, 0);
打印时,我仍然可以在注册表中看到ref
个条目。为什么luaL_unref
不会删除未引用的条目,以便gc可以收集它们?
答案 0 :(得分:1)
正如@siffiejoe在评论中指出的那样,Lua的辅助图书馆使用" freelist"跟踪自由索引漏洞的机制,该列表永远不会缩小,即它的大小始终等于峰值分配 - 即从大小到速度的权衡。您可以检查实现以找出基础逻辑。
如果您确定注册表中没有活动的引用,则可以手动清除整数键(请参阅下面的注释)。如果您想要一个完全空的注册表,那么lua_newtable(L), lua_replace(L, LUA_REGISTRYINDEX)
将会这样做。这不是一个好主意 - 请参阅下面的答案。
(请注意,您可能无法简单地检查所有引用是否均衡,因为某些代码可能会引用整数值。但我可能错了。)