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