1)lua的GC默认是自动回收的,当一个对象的引用计数为0时,它就会被GC所回收。
2)lua中的表默认是强引用的,当你把某个对象放入表中时,就是生成一个对它的强引用(对象的引用计数 1),在对象的引用计数没有为0之前不会被GC回收;
3)如果把一个表声明为弱引用,则当把某个对象放如表中时,生成一个弱引用(对象不会被引用计数,可以理解为引用计数 0);如果一个对象只被弱引用表所引用(对象的引用计数为0),则会被下一次GC自动回收
所以弱引用表weak table的用途一般都是出于GC考虑的
注意:以上所指对象不包括值类型:number、boolean 当K为弱引用
代码语言:javascript复制t = {}
--标记表t的key为弱引用
setmetatable(t, {__mode = "k"})
key1 = {name = "key1"}
key2 = {name = "key2"}
t[key1] = 1
t[key2] = 2
--手动调用GC来测试
collectgarbage()
for k, v in pairs(t) do
print(k.name, v)
end
print("-----------------------------------------")
key1 = nil
--手动调用GC来测试
collectgarbage()
for k, v in pairs(t) do
print(k.name, v)
end
输出
代码语言:javascript复制key1 1
key2 2
-----------------------------------------
key2 2
解析:
- key1 = {name = “key1”} 这个key1引用加1
- t[key1] 不会导致key1 1
- key1 = nil ,key1引用-1, = 0
- 接下来被GC了
可以看到当key1 = nil 并手动调用GC后,key1所占的内存被回收了,t中也访问不到key1了
- 如果注释setmetatable(t, {__mode = “k”}) 这个语句,t[key1] 会导致key1引用 1,即使 key1 = nil ,仍然访问到t[key1]