[Lua] 内存泄漏与垃圾回收

26 篇文章 3 订阅

转自:https://www.cnblogs.com/lyh916/p/7896072.html

一.内存泄漏的检测

Lua的垃圾回收是自动进行的,但是我们可以collectgarbage方法进行手动回收。collectgarbage方法的第一个参数是字符串,代表操作类型,第二个参数只有某些操作类型有,是该操作所需要的参数。常用的操作类型有:

collect:执行一次完整的垃圾回收

count:返回当前使用的内存,单位是kb

function PrintCount()
    print("内存为:", collectgarbage("count"))--输出当前内存占用
end

function A()
    collectgarbage("collect")--进行垃圾回收,减少干扰
    PrintCount()
    local a = {}
    for i=1,5000 do
        table.insert(a, {})
    end
    PrintCount()
    collectgarbage("collect")
    PrintCount()
end
    
A()
PrintCount()
collectgarbage("collect")
PrintCount()

 

输出如下。第二次输出,可以得出分配内存为303-19=284kb。第三次输出,因为局部变量a还在生命周期内,所以手动回收内存并没有影响。第四次输出,因为Lua的自动回收是每隔一段时间进行的,所以无影响。第五次输出,在执行手动回收后,分配的内存得到了回收,没有发生内存泄漏。

接着对上面的例子进行少量修改:

function PrintCount()
    print("内存为:", collectgarbage("count"))--输出当前内存占用
end

function A()
    collectgarbage("collect")--进行垃圾回收,减少干扰
    PrintCount()
    a = {}--修改1
    for i=1,5000 do
        table.insert(a, {})
    end
    PrintCount()
    collectgarbage("collect")
    PrintCount()
end
    
A()
PrintCount()
collectgarbage("collect")
PrintCount()

--修改2
a = nil
collectgarbage("collect")
PrintCount()

输出如下。第五次输出,因为a改为了全局变量,所以没办法进行回收。如果之后再也不需要使用a,那么就出现了内存泄漏了。为了避免这种情况,可以将a置空,此时a就会被lua判定为垃圾,就能进行回收了。因此,可以得出一个减少内存泄漏的方法:尽量用局部变量,这样当其生命周期结束时,就能被回收;对于全局变量,可以根据使用情况置空,及时回收内存。另外,如果某些情况出现或即将出现内存占用过大的情况,可以考虑手动去进行垃圾回收。

 

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值