国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 開發(fā) > 綜合 > 正文

Lua中釋放table占用內(nèi)存的方法

2024-07-21 23:04:41
字體:
供稿:網(wǎng)友

table的大小是動態(tài)變化的。看如下代碼:

 

復(fù)制代碼 代碼如下:

tb = {1,2,3} --數(shù)組大小4,hash表大小1(不管hash表有沒有存數(shù)據(jù),它的大小最小為1) 
 
tb[5] = 5 
tb[100] = 100 --數(shù)組大小4,hash表大小2 

因為后插入的兩個數(shù)的key過于離散,所以它們被保存到hash表中。最終tb的大小為4+2=6。
這時我們對table進行刪除操作:

 

 

復(fù)制代碼 代碼如下:

tb[1] = nil 
tb[2] = nil 
tb[3] = nil 
tb[5] = nil 
tb[100] = nil 

 

這時tb里面沒有數(shù)據(jù)了,但tb的大小還是6,tb占用的內(nèi)存空間并沒有釋放!
這里提供兩種方式來釋放tb所占的內(nèi)存空間。

第一種:

將tb設(shè)為nil,然后等垃圾收集或強制執(zhí)行一次垃圾收集(collectgarbage)。

第二種:

用一個之前沒用過的key對tb的內(nèi)容賦nil值。要找一個未使用過的key很簡單,直接構(gòu)造一個table當key就可以了,比如tb[{}]=nil。

第一種是正規(guī)的做法,第二種只是一種演示,不實用。

下面解釋一下第二種方法為什么能釋放table占用的內(nèi)存空間。

只有兩種情況會設(shè)置table的大小,一種是構(gòu)造table的時候,一種是用一個新key向table插入一個值的時候。

前者不用解釋,那是必須的。后者是為了提高table中array的利用率而進行的優(yōu)化。

當向table插入一個新值時,lua會計算新值插入后整個table中array與hash的情況(有些值被設(shè)nil,有些值從hash移到array),

重新計算變化后的table,算出新的array與hash的大小,重新分配空間。

所以,盡管上面tb中的所有值都是nil,但由于沒有向table插入一個新值,沒有觸發(fā)table的重新分配,所以空間并沒有釋放。

PS:為什么用一個老key沒效果呢?這是因為老key對應(yīng)的table空間還在,lua會直接使用老空間而不去計算新空間。

 
發(fā)表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發(fā)表
主站蜘蛛池模板: 贡嘎县| 大丰市| 潍坊市| 奉贤区| 黄大仙区| 天津市| 离岛区| 临漳县| 海门市| 凤冈县| 南通市| 宜兰市| 黑山县| 巫山县| 康定县| 藁城市| 马龙县| 玉林市| 青龙| 瑞昌市| 同江市| 五台县| 来凤县| 二连浩特市| 信阳市| 灌云县| 井冈山市| 泸水县| 高雄市| 邮箱| 靖州| 麻江县| 常宁市| 天柱县| 连江县| 延庆县| 克东县| 安溪县| 改则县| 大姚县| 吴桥县|