Android采用虛擬內(nèi)存和分頁,支持交換,Android使用顯式分配的共享內(nèi)存區(qū)域。
一、垃圾回收
? ?Android的垃圾收集器不帶壓縮整理功能(Compact),即不會(huì)對(duì)Heap做碎片整理。Android的內(nèi)存堆是分代式(Generational)的,意味著它會(huì)將所有分配的對(duì)象進(jìn)行分代,然后分代跟蹤這些對(duì)象。 例如,最近分配的對(duì)象屬于年輕代(Young Generation)。 當(dāng)一個(gè)對(duì)象長時(shí)間保持活動(dòng)狀態(tài)時(shí),它可以被提升為年老代(Older Generation),之后還能進(jìn)一步提升為永久代(Permanent Generation)
二、內(nèi)存分配與回收
Andorid采用彈性分配的策略,隨著應(yīng)用程序的的需要會(huì)逐步增加內(nèi)存,直達(dá)最大的內(nèi)存限制,Android為每個(gè)應(yīng)用程序設(shè)置了堆大小的硬性限制。 該限制因設(shè)備而異,取決于設(shè)備總體可用的RAM。 如果應(yīng)用程序已達(dá)到該限制并嘗試分配更多內(nèi)存,則會(huì)收到 OutOfMemoryError。
三、應(yīng)用切換
? ?應(yīng)用切換時(shí),會(huì)把當(dāng)前應(yīng)用的進(jìn)程緩存起來,采用LRU算法,以便用戶再次進(jìn)入,快速的切換應(yīng)用,當(dāng)內(nèi)存不夠時(shí),則從緩存中
取出最少使用的那個(gè)進(jìn)程,不過會(huì)綜合考慮進(jìn)程所占用的大小,占用的約大約有可能清除。Linux系統(tǒng)在進(jìn)程活動(dòng)停止后就結(jié)束該進(jìn)程,而Android系統(tǒng)則會(huì)在內(nèi)存中盡量長時(shí)間的保持應(yīng)用進(jìn)程,直到系統(tǒng)需要更多內(nèi)存為止。