Lua使用基于被內置在Lua某些算法的垃圾收集自動內存管理??梢宰詣觾却婀芾淼慕Y果,作為一個開發者:
Lua使用運行不時收集死的對象時,不再從Lua程序中訪問垃圾收集器。
所有對象,包括表,用戶數據,函數,線程,字符串等受自動內存管理。 Lua使用增量標記和使用兩個數字來控制其垃圾回收周期即垃圾收集暫停和垃圾收集器的步驟事半功倍清除收集器。這些值是在百分比和100的值是常等于1。
垃圾收集暫停
垃圾收集停頓被用于控制多長時間的垃圾收集器需要等待,之前;它是由Lua的自動內存管理再次調用。數值低于100就意味著Lua中不會等待下一個周期。此值的類似地較高的值將導致垃圾收集器是緩慢的并且性質上較不積極。200表示該集合等待的總內存在使用中要開始一個新的周期開始前的兩倍。因此,根據不同的性質和應用的速度,有可能要求改變該值來獲得在Lua應用的最佳性能。
垃圾收集器的步驟事半功倍
這一步乘數控制垃圾收集在Lua程序的內存分配的相對速度。較大的步長值將導致垃圾收集器要更侵蝕性,同時也提高了垃圾收集的每個增量步的步長大小。值小于100可能經常導致避免垃圾收集器沒有完成其周期和其一般不是優選的。默認值是200,這意味著垃圾收集器運行的兩倍的內存分配的速度。
垃圾收集器函數
作為開發人員,我們確實有過讓Lua自動內存管理。為此,有以下幾種方法。
使用垃圾收集器例如一個簡單的例子如下所示。
print(collectgarbage("count"))
mytable = nil
print(collectgarbage("count"))
print(collectgarbage("collect"))
print(collectgarbage("count"))
當我們運行上面的程序,會得到下面的輸出。請注意,這樣的結果會有所不同,由于在操作系統中,Lua自動內存管理功能可能也有差異。
可以在上面的程序看出,一旦垃圾回收完成后,既可以減少使用內存。但是它也不是強制性的調用。即使我們不給調用,它也會自動在后一階段在預定時間之后由Lua解釋器執行。
顯然我們可以改變,如果需要使用垃圾收集器的這些功能行為。這些功能提供了一點額外的能力,為開發者處理復雜情況。根據不同的內存需要執行程序類型,可能會或可能不會使用此功能。但在應用程序的內存使用情況,并在程序本身,以避免在部署后不想要對結果進行檢查。
|
新聞熱點
疑難解答