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