1)lua的GC默认是自动回收的,当一个对象的引用计数为0时,它就会被GC所回收。
2)lua中的表默认是强引用的,当你把某个对象放入表中时,就是生成一个对它的强引用(对象的引用计数+1),在对象的引用计数没有为0之前不会被GC回收;
3)如果把一个表声明为弱引用,则当把某个对象放如表中时,生成一个弱引用(对象不会被引用计数,可以理解为引用计数+0);如果一个对象只被弱引用表所引用(对象的引用计数为0),则会被下一次GC自动回收
所以弱引用表weak table的用途一般都是出于GC考虑的
注意:以上所指对象不包括值类型:number、boolean 当K为弱引用
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
输出
key1 1
key2 2
-----------------------------------------
key2 2
解析:
可以看到当key1 = nil 并手动调用GC后,key1所占的内存被回收了,t中也访问不到key1了