Lua垃圾收集
Lua使用基於被內置在Lua某些算法的垃圾收集自動內存管理。可以自動內存管理的結果,作爲一個開發者:
沒有必要擔心的對象分配內存。
無需釋放他們時,不再需要可將其設置爲nil。
Lua使用運行不時收集死的對象時,不再從Lua程序中訪問垃圾收集器。
所有對象,包括表,用戶數據,函數,線程,字符串等受自動內存管理。 Lua使用增量標記和使用兩個數字來控制其垃圾回收週期即垃圾收集暫停和垃圾收集器的步驟事半功倍清除收集器。這些值是在百分比和100的值是常等於1。
垃圾收集暫停
垃圾收集停頓被用於控制多長時間的垃圾收集器需要等待,之前;它是由Lua的自動內存管理再次調用。數值低於100就意味着Lua中不會等待下一個週期。此值的類似地較高的值將導致垃圾收集器是緩慢的並且性質上較不積極。200表示該集合等待的總內存在使用中要開始一個新的週期開始前的兩倍。因此,根據不同的性質和應用的速度,有可能要求改變該值來獲得在Lua應用的最佳性能。
垃圾收集器的步驟事半功倍
這一步乘數控制垃圾收集在Lua程序的內存分配的相對速度。較大的步長值將導致垃圾收集器要更侵蝕性,同時也提高了垃圾收集的每個增量步的步長大小。值小於100可能經常導致避免垃圾收集器沒有完成其週期和其一般不是優選的。默認值是200,這意味着垃圾收集器運行的兩倍的內存分配的速度。
垃圾收集器函數
作爲開發人員,我們確實有過讓Lua自動內存管理。爲此,有以下幾種方法。
collectgarbage("collect"): 執行垃圾回收的一個完整週期。
collectgarbage("count"): 返回當前使用的千字節的程序內存量
collectgarbage("restart"): 如果垃圾收集器已經停止,將重新啓動它。
collectgarbage("setpause"): 設置給定爲第二參數除以100至垃圾收集器暫停變量的值。它的用途是作爲討論的一點上面。
collectgarbage("setstepmul"): 設置給定爲第二參數除以100到垃圾步驟乘數的變量的值。它的用途是作爲討論的一點上面。
collectgarbage("step"): 運行垃圾回收的一步。第二個參數是越大step也會變大。在收集的垃圾將返回true,如果觸發的步驟是一個垃圾收集週期的最後一步。
collectgarbage("stop"): 停止垃圾收集器,如果它的運行。
使用垃圾收集器例如一個簡單的例子如下所示。
mytable = {"apple", "orange", "banana"} print(collectgarbage("count")) mytable = nil print(collectgarbage("count")) print(collectgarbage("collect")) print(collectgarbage("count"))
當我們運行上面的程序,會得到下面的輸出。請注意,這樣的結果會有所不同,由於在操作系統中,Lua自動內存管理功能可能也有差異。
20.9560546875
20.9853515625
0
19.4111328125
可以在上面的程序看出,一旦垃圾回收完成後,既可以減少使用內存。但是它也不是強制性的調用。即使我們不給調用,它也會自動在後一階段在預定時間之後由Lua解釋器執行。
顯然我們可以改變,如果需要使用垃圾收集器的這些功能行爲。這些功能提供了一點額外的能力,爲開發者處理複雜情況。根據不同的內存需要執行程序類型,可能會或可能不會使用此功能。但在應用程序的內存使用情況,並在程序本身,以避免在部署後不想要對結果進行檢查。