如果我首先在lua的注册表中放置一些内容:
int ref = luaL_ref(L, LUA_REGISTRYINDEX);
Run Code Online (Sandbox Code Playgroud)
然后不要参考ref:
luaL_unref(L, LUA_REGISTRYINDEX, ref);
Run Code Online (Sandbox Code Playgroud)
并启动垃圾收集器:
lua_gc(L, LUA_GCCOLLECT, 0);
Run Code Online (Sandbox Code Playgroud)
ref打印时,我仍然可以在注册表中看到这些条目.为什么不luaL_unref删除未引用的条目,以便gc可以收集它们?
正如 @siffiejoe 在评论中指出的,Lua 的辅助库使用“freelist”机制来跟踪空闲索引空洞,并且该列表永远不会缩小,即它的大小始终等于峰值分配 \xe2\x80\x94 即大小-速度权衡。您可以检查实现以找出底层逻辑。
\n\n如果您确定注册表中没有剩余的活动引用,您可以手动清除整数键(请参见下面的注释)。如果您想要一个完全空的注册表,那么lua_newtable(L), lua_replace(L, LUA_REGISTRYINDEX)就这样做。尽管 \xe2\x80\x94 请参阅此答案下面的评论,但这不是一个好主意。
(请注意,您可能无法简单地检查所有引用是否平衡,因为某些代码可能引用整数值。不过,我可能是错的。)
\n| 归档时间: |
|
| 查看次数: |
554 次 |
| 最近记录: |