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

解析:

  1. key1 = {name = “key1”} 这个key1引用加1
  2. t[key1] 不会导致key1 +1
  3. key1 = nil ,key1引用-1, = 0
  4. 接下来被GC了

可以看到当key1 = nil 并手动调用GC后,key1所占的内存被回收了,t中也访问不到key1了

  1. 如果注释setmetatable(t, {__mode = “k”}) 这个语句,t[key1] 会导致key1引用 +1,即使 key1 = nil ,仍然访问到t[key1]