如果我首先使用以下命令将某些内容放入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的辅助库使用“自由列表”机制来跟踪自由索引漏洞,并且该列表永远不会缩小,即其大小始终等于峰值分配-即大小与速度之间的权衡。您可以检查实现以找出潜在的逻辑。
如果您确定注册表中没有剩余的活动引用,则可以手动清除整数键(请参见下面的注释)。如果您想要一个完全空的注册表,则lua_newtable(L), lua_replace(L, LUA_REGISTRYINDEX)
可以这样做。不过,这不是一个好主意-请参阅此答案下方的评论。
(请注意,您可能无法简单地检查所有引用是否均已平衡,因为某些代码可能会引用整数值。不过,对此我可能是错的。)
本文收集自互联网,转载请注明来源。
如有侵权,请联系 [email protected] 删除。
我来说两句