lua的弱弱引用表

本文详细解析了Lua语言中弱表(weaktable)的使用方法及其与垃圾回收(GC)的关系,通过具体代码示例展示了如何利用弱表进行内存管理,帮助读者理解并掌握Lua的高级特性。

lua有GC。细节无需太关注,知道些主要的即可。能local就一定不要global;

还有在数组里的对象,除非显式=nil,否则非常难回收;

只是能够用弱引用表来告诉GC。外部引用为0,就不要管我,请del it。

weak table是通过元表实现,元表里的__mode字段包括k或者v;k表示key为弱引用;v表示value为弱引用。

1、首先看一个普通的样例:

a = {}

key = {}
a[key] = 1
key = {}
a[key]=2

collectgarbage()

for k,v in pairs(a)
	do print(v)
end

输出是:

>lua -e "io.stdout:setvbuf 'no'" "test.lua" 
1
2
>Exit code: 0

这里没有什么,就是把a里的东西所有打印出来了。


2、然后设置a的元表 包括k,就表示a的key是弱引用

a = {}

b = {__mode = 'k'}
setmetatable(a, b)

key = {}
a[key] = 1
key = {}
a[key]=2

collectgarbage()

for k,v in pairs(a)
	do print(v)
end
key经过一次覆盖,除了a没有其它引用,并且由于a的key为弱引用,所以能够回收了。正如预料输出:

>lua -e "io.stdout:setvbuf 'no'" "test.lua" 
2
>Exit code: 0

3、然后看一个value为weak table的样例:

a = {}

b = {__mode = 'v'}
setmetatable(a, b)

key = {11,12}
a[1] = key
key = {13}
a[2]= key

collectgarbage()

for k,v in pairs(a) do
	for m,n in pairs(v)
	do print(n)
	end
end

key经过覆盖。前一个被回收啦。

终于输出:

>lua -e "io.stdout:setvbuf 'no'" "test.lua" 
13
>Exit code: 0


经过上面的分析,你稍微明确weak table木有。假设木有,那就再看看书吧。



转载于:https://www.cnblogs.com/ldxsuanfa/p/10861740.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值