如果我首先在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可以收集它们?
正如@siffiejoe在
评论中指出的那样,Lua的辅助库使用“freelist”机制来跟踪自由索引漏洞,并且该列表永远不会缩小,即它的大小总是等于峰值分配 – 即从大小到速度的权衡.您可以检查实现以找出基础逻辑.
如果您确定注册表中没有活动的引用,则可以手动清除整数键(请参阅下面的注释).如果你想要一个完全空的注册表,那么lua_newtable(L),lua_replace(L,LUA_REGISTRYINDEX)就可以了.这不是一个好主意 – 请参阅此答案下方的评论.
(请注意,您可能无法简单地检查所有引用是否均衡,因为某些代码可能会引用整数值.虽然我可能错了.)