table的大小是動態變化的。看如下代碼:
這時tb里面沒有數據了,但tb的大小還是6,tb占用的內存空間并沒有釋放!
這里提供兩種方式來釋放tb所占的內存空間。
第一種:
將tb設為nil,然后等垃圾收集或強制執行一次垃圾收集(collectgarbage)。
第二種:
用一個之前沒用過的key對tb的內容賦nil值。要找一個未使用過的key很簡單,直接構造一個table當key就可以了,比如tb[{}]=nil。
第一種是正規的做法,第二種只是一種演示,不實用。
下面解釋一下第二種方法為什么能釋放table占用的內存空間。
只有兩種情況會設置table的大小,一種是構造table的時候,一種是用一個新key向table插入一個值的時候。
前者不用解釋,那是必須的。后者是為了提高table中array的利用率而進行的優化。
當向table插入一個新值時,lua會計算新值插入后整個table中array與hash的情況(有些值被設nil,有些值從hash移到array),
重新計算變化后的table,算出新的array與hash的大小,重新分配空間。
所以,盡管上面tb中的所有值都是nil,但由于沒有向table插入一個新值,沒有觸發table的重新分配,所以空間并沒有釋放。
PS:為什么用一個老key沒效果呢?這是因為老key對應的table空間還在,lua會直接使用老空間而不去計算新空間。
新聞熱點
疑難解答