《電子技術應用》
您所在的位置:首頁 > 嵌入式技術 > 設計應用 > Android系統的內存管理研究
Android系統的內存管理研究
摘要: 本文將集中分析Android的內存管理,因為Android系統是在Linux系統的基礎上發展起來的,所以在介紹Linux基本的內存管理的基礎上對Android的內存管理進行研究。
Abstract:
Key words :

1 Android系統概述

Android是Google(谷歌)公司開發的一款專門為移動設備打造的操作系統。2005年谷歌公司收購Android Inc公司后,于2007年研發了基于Linux的操作系統Android。2008年,TMobile與HTC公司共同研發了第一款Android手機——HTC G1。Android的發展速度非常驚人,僅僅3年便超過了Symbian系統,并且有強大的OEM支持以及眾多的開發者。

Android基于Linux平臺,主要由操作系統、中間件、用戶界面和應用軟件組成。采用的是軟件堆棧的結構,操作系統的底層僅提供最基本的系統功能。在Android系統中,基本上使用的是標準的Linux2.6內核,但是Google為了讓Android更適合移動手持設備,對Linux內核進行了各種優化和增強。除了Linux的通用代碼外,主要包含體系結構和處理器、Android特定的驅動程序和標準的設備驅動程序3個方面的內容。Android對Linux內核的增強主要包括Alarm(硬件鬧鐘)、Ashmem(匿名內存共享)、Low Memory Killer(低內存管理)、Logger(日志管理)等。本文將集中分析Android的內存管理,因為Android系統是在Linux系統的基礎上發展起來的,所以在介紹Linux基本的內存管理的基礎上對Android的內存管理進行研究。

2 Linux內存管理

在內存管理方面,Linux系統新舊兩個版本(2.6之前和之后)之間有很大的不同。由于Android系統是基于Linux2.6.x內核的,本文主要介紹Linux2.6在內存管理方面的基本內容。

2.1 反向映射機制

Linux2.6引入了基于對象的反向映射機制,這種方法為物理頁面設置一個用于反向映射的鏈表,但是鏈表上的節點并不是引用了該物理頁面的所有頁表項,而是相應的虛擬內存區域(vm_area_struct結構)。虛擬內存區域通過內存描述符(mm_struct結構)找到頁全局目錄,從而找到相應的頁表項。相對于前一種方法來說,用于表示虛擬內存區域的描述符比用于表示頁面的描述符要少得多,所以遍歷后邊這種反向映射鏈表所消耗的時間也會少很多。

page結構中與基于對象的反向映射相關的關鍵字段有兩個:_mapcount和mapping。基于對象的反向映射的實現如下:

struct page{

atomic_t_mapcount;

union{

……

struct{

……

struct address_space*mapping;

};

};

字段_mapcount表明共享該物理頁面的頁表項的數目,該計數器可用于快速檢查該頁面除所有者之外有多少使用者在使用,初始值是-1,每增加一個使用者,該計數器加1。

字段mapping用于區分匿名頁面和基于文件映射的頁面。如果該字段的最低位置被置位,那么該字段包含的是指向anon_vma結構(用于匿名頁面)的指針;否則,該字段包含指向address_space結構的指針(用于基于文件映射的頁面)。

2.2 Linux頁面回收

Linux中頁面回收主要通過兩種方式觸發:一種是由“內存嚴重不足”事件觸發;另一種是由后臺進程kswapd觸發,該進程周期性地運行,一旦檢測到內存不足,就會觸發頁面回收操作。這里主要介紹shrink_zone()函數,此函數是Linux操作系統實現頁面回收的最核心的函數之一,它實現了對一個內存區域的頁面進行回收的功能。該函數主要做了兩件事:

① 將某些頁面從active鏈表移到inactive鏈表,這是由函數shrink_active_list()實現的;

② 從inactive鏈表中選定一定數目的頁面,將其放到一個臨時鏈表中,這由函數shrink_inactive_list()完成。

該函數最終會調用shrink_page_list()去回收這些頁面。

2.3 OOMKiller機制

OOM(Out of Memory)是標準Linux內核(kernel)的一種內存管理機制,當系統內存耗盡時,OOM會選擇性的殺掉一些進程以求釋放一些內存。

Linux在2.6.36內核中修正了OOMKiller的行為,跟之前的OOMKiller相比,主要體現在3個方面:第一,將物理內存頁面的使用作為基準而不是虛擬地址空間的大小;第二,導出用戶策略的控制權;第三,內核有了一個簡單而合理的默認策略。

Linux下有3種Overcommit的策略:0,啟發式策略;1,永遠允許Overcommit,這種策略適合那些不能承受內存分配失敗的應用;2,永遠禁止Overcommit,這種策略下系統所能分配的內存不會超過swap+RAM*系數。在Linux系統中,只要存在Overcommit,就可能會有OOMKiller跳出來。當OOMKiller跳出來的時候,期望它可以殺掉沒用的且耗內存多的程序,這就需要一個選擇目標的策略。Linux下這個選擇目標的策略也在隨著內核的改進不斷的演化。在Linux下每個進程都會有個OOM權重,在/proc/ /oom_adj中,取值是-17~+15,取值越高,越容易被殺掉。用戶可以通過設置這些值來影響OOMKiller作出決策。這個值是系統綜合進程的內存消耗量、CPU時間、存活時間和oom_adj計算出的,消耗內存越多分值就會越高。除此之外,Linux在計算進程的內存消耗的時候,會將子進程所耗內存的一半同時算到父進程中。

3 Android的低內存管理

Android是一個多任務系統,當啟動一個程序時會消耗一定的時間。為了加快運行速度,當退出一個程序時,Android并不會立即殺掉它,這樣當用戶重新運行該程序時,可以很快地啟動。但隨著系統中保留的程序越來越多,內存肯定會出現不足,此時就有了Android的低內存管理(Low Memory Killer)機制。

3.1 Low Memory Killer機制

Low Memory Killer是在標準Linux kernel的OOM基礎上修改而來的一種內存管理機制,基于oom_adj和占用內存的大小來選擇Bad進程。對應于每個oom_adj都有一個空閑內存的閾值,Android kernel每隔一段時間會檢查當前空閑內存是否低于某個閾值。如果是,則殺死oom_adj最大的Bad進程。如有兩個以上的Bad進程oom_adj相同,則殺死其中占用內存最多的進程。

3.2 Low Memory Killer的實現

Low Memory Killer是以內核驅動的形式實現的,該實現位于drivers/misc/lowmemorykiller.c中,通過注冊Cache Shrinker實現。Cache Shrinker是標準Linux kernel回收頁面的一種機制,它由內核線程kswapd監控,當空閑內存頁面不足時,kswapd會調用注冊的Shrinker回調函數,來回收內存頁面。lowmem_shrink是這個驅動的核心實現,當內存不足時就會調用lowmem_shrink方法來殺掉某些內存。lowmem_shrink用兩個數組作為選擇Bad進程的依據,定義如下:

static int lowmem_adj[6]={0,1,6,12};

static int lowmem_adj_size=4;

static size_t lowmem_minfree[6]={3*512,2*1024,4*1024,16*1024};

lowmem_minfree保存空閑內存的閾值,單位是一個頁面4 KB,lowmem_adj保存每個閾值對應的優先級。lowmem_shrink首先計算當前空閑內存的大小,如果小于某個閾值,則以該閾值對應的優先級為基準,遍歷各個進程,計算每個進程占用內存的大小,找出優先級大于基準優先級的進程,在這些進程中選擇優先級最大的殺死。如果優先級相同,則選擇占用內存最多的進程。lowmem_shrink殺死進程的方法是向進程發送一個不可以忽略或阻塞的SIGKILL信號:force_sig(SIGKILL,selected)。

3.3 內存管理

Android中的內存管理分為兩個部分:第一部分是當應用程序關閉后,后臺對應的進程并沒有真正退出,以便下次再啟動時能夠快速啟動;第二部分是當系統內存不夠時,Ams會主動根據內存管理機制退出優先級較低的進程。這里主要介紹第二部分。

Ams(Activity manager service)運行在Java環境中,而Android采用Dalvik虛擬機,應用程序和Ams運行在兩個獨立的虛擬機中,Ams并不會知道應用程序的內存分配情況。那內存是怎么管理的呢?在Android中運行一個Low Memory Killer進程,該進程啟動時會首先在Linux內核中把自己注冊為一個OOM Killer,即當Linux內核的內存管理模塊檢測到系統內存低的時候就會通知已經注冊的OOM進程,然后這些OOM Killer就可以根據各種規則進行內存釋放。當內存滿足低的條件時,Linux內核管理模塊通知OOM Killer,Killer則根據Ams所告知的優先級,強制退出優先級低的應用程序。

4 Android內存優化研究

Android內存管理機制主要是針對進程的優先級和內存占用情況來對進程進行管理的,所以對內存管理的優化也主要體現在對進程閾值的設定上。

4.1 Android進程

Android根據進程的重要性,將進程分為以下幾類:

① FOREGROUD_APP(前臺進程),用戶正在使用的進程和一些系統進程。

② VISIBLE_APP(可見的進程)跟FOREGROUD_APP類似,用戶正在使用或看得到,它們的區別就是VISIBLE_APP可能不是用戶關注的程序,但是用戶看得到,或者沒有覆蓋到整個屏幕,只有屏幕的一部分。

③ SECONDARY_SERVER(后臺進程)是被切換到后臺的進程,后臺進程的管理策略有很多種,Android采用一種消極的方式,即盡可能地保留后臺程序,這樣可以很好地提高再次啟動的速度。

④ HIDDEN_APP(隱藏的程序)是用戶看不見但是還在運行的程序,跟②有一定的區別。

⑤ CONTENT_PROVIDER(內容供應節點)沒有程序實體,僅提供內容供別的進程使用,比如日歷供應節點、郵件供應節點等。

⑥ EMPTY_APP(空進程)既不提供服務,也不提供內容。當進程退出時,系統會自動為其保留一個空進程,目的也是為了保證程序再次啟動的速度。

以上每個進程都會有個oom_adj值,①~⑥分別為0、1、2、7、14、15。

除了程序的重要性,Android系統還會維護另外一張表,進程優先級及閾值對應關系如表1所列。

表1 進程優先級及閾值對應關系

 

http://www.21ic.com/d/file/201301/9d4593b4d8f191347eb631c991832f84.gif

這個表定義了一個對應關系,每個警戒值對應了一個重要性值,當系統的可用內存低于某個警戒值時,就殺掉所有大于該警戒值對應的重要性的程序。

4.2 內存管理優化

Android的Low Memory Killer機制基本上可以滿足普通用戶的需求,但是針對于某些特定用戶就需要對特定程序進行某些設置,從而手動地參與內存管理。對進程的優化主要設置6類進程的閾值,系統閾值存在的問題包括:第一,各類進程管理策略的閾值相當接近,在實際程序運行中,很容易導致多種類型的進程同時被關閉;第二,閾值上限較低,一般手機啟動后,可用內存在50~100 MB左右,但隨著手機的使用,內存會逐漸減小,最后降低到24 MB左右,但24 MB相對較低,會降低系統的反應速度。

優化原則:拉開各進程的閾值層次,使得進程管理機制能更有效地工作;提高閾值上限,空出更多的空余內存,以提升系統整體的運行速度;前臺進程、可見進程和次要服務是與用戶體驗息息相關的內容,這部分的進程管理策略要相對保守,給這些進程留下足夠的運行空間;壓榨無用進程,騰出內存空間給主要程序使用。

4.3 內存測試

本文以OK6410開發板為例,對內存優化進行測試,OK6410采用的是Android2.3.4系統,256 MB內存。系統默認內存配置如圖1所示。

http://www.21ic.com/d/file/201301/8aed32a8c8a2b196ed04ae53f43e949b.gif

圖1 系統默認內存配置(MB)

這里采用測試程序對系統性能進行測試評分,在系統默認配置情況下優化前的內存測評如圖2所示。

http://www.21ic.com/d/file/201301/8aed32a8c8a2b196ed04ae53f43e949b.gif

圖2 優化前的內存測評

http://www.21ic.com/d/file/201301/ca2f77248cf76e9a21aaa8562562de72.gif

圖3 優化內存分配(MB)

針對某些特定需求,以游戲玩家為例,此時只需要游戲運行有足夠的內存空間,而對多任務的需求不高。因此,可以盡量壓榨后臺進程、內容供應節點和空進程,將內存盡可能地留給前臺進程和系統程序,進而提升游戲運行速度。在此設置的值如圖3所示。

此設置大幅度提升了后臺進程、內容供應節點和空進程的閾值,這樣當系統內存小于100 MB時就可以最先殺死空進程,然后根據內存情況,進而殺死后臺進程和內容供應節點。如此,就為前臺進程和系統進程留下了足夠的內存空間,很好地滿足特定用戶的需求。在此情況下的系統測評如圖4所示。

http://www.21ic.com/d/file/201301/e193d583d7c8c8514b6aec0cc02a984e.gif

圖4 優化后測評分數

通過圖2跟圖4的分數以及理論分析,可以發現系統在內存方面的性能有了明顯的提升。

結語

Android的內存管理基于Linux,并在此基礎上有了很大的改變,在性能和穩定性方面為移動設備提供了很好的支持。其本身的內存管理機制可以合理地對每個進程進行管理,用戶可以根據自己的需求通過對各個級別的優先級及閾值的改變參與到系統內存的管理中來。

此內容為AET網站原創,未經授權禁止轉載。
热re99久久精品国产66热_欧美小视频在线观看_日韩成人激情影院_庆余年2免费日韩剧观看大牛_91久久久久久国产精品_国产原创欧美精品_美女999久久久精品视频_欧美大成色www永久网站婷_国产色婷婷国产综合在线理论片a_国产精品电影在线观看_日韩精品视频在线观看网址_97在线观看免费_性欧美亚洲xxxx乳在线观看_久久精品美女视频网站_777国产偷窥盗摄精品视频_在线日韩第一页
  • <strike id="ygamy"></strike>
  • 
    
      • <del id="ygamy"></del>
        <tfoot id="ygamy"></tfoot>
          <strike id="ygamy"></strike>
          国外成人网址| 在线亚洲精品福利网址导航| 国产精品久久久久9999吃药| 日韩午夜在线视频| 国产精品成人观看视频国产奇米| 国产精品日韩欧美| 久久亚洲一区| 久久超碰97中文字幕| 欧美风情在线观看| 在线精品视频一区二区三四| 国产精品少妇自拍| 伊人久久亚洲美女图片| 欧美婷婷六月丁香综合色| 久久精品一区二区三区中文字幕| 国产日韩欧美一区二区三区四区| 国产欧美综合一区二区三区| 亚洲美女网站| 亚洲美女精品成人在线视频| 毛片精品免费在线观看| 国产亚洲欧美中文| 欲香欲色天天天综合和网| 欧美日韩中字| 一区二区三区高清不卡| 亚洲激情专区| 午夜精品网站| 亚洲午夜91| 国产乱码精品一区二区三区av| 欧美国产日韩一区二区在线观看| 91久久精品一区二区别| 一本色道88久久加勒比精品| 亚洲校园激情| 国产日韩欧美视频在线| 香蕉视频成人在线观看| 国产视频一区在线观看一区免费| 欧美高清成人| 国内不卡一区二区三区| 久久一区二区三区超碰国产精品| 在线播放中文字幕一区| 国产精品毛片在线| 亚洲国产成人在线播放| 在线免费高清一区二区三区| 欧美精品一区二区高清在线观看| 性欧美激情精品| 亚洲第一在线综合网站| av不卡免费看| 狠狠网亚洲精品| 一区二区三区导航| 欧美精品www在线观看| 一区二区三区你懂的| 国产精品亚洲综合久久| 欧美午夜美女看片| 亚洲永久免费| 日韩视频中午一区| 亚洲国产另类精品专区| 久久久久久尹人网香蕉| 欧美精品在线观看| 国内偷自视频区视频综合| 国产日韩一级二级三级| 国产一区二区三区av电影| 欧美天天视频| 午夜精品福利电影| 亚洲日本成人在线观看| 亚洲视频在线观看三级| 一区二区三区在线看| 国产精品久久久久久久免费软件| 国产精品免费视频xxxx| 久久精品成人一区二区三区蜜臀| 午夜精品亚洲一区二区三区嫩草| 欧美成人资源| 欧美一区午夜视频在线观看| 久久裸体视频| 欧美高清在线观看| 欧美午夜一区二区三区免费大片| 亚洲一区免费网站| 国产精品中文字幕在线观看| 亚洲国产精品va在线看黑人| 国产精品久久久久久久9999| 在线观看欧美日本| 国产精品xnxxcom| 欧美成人免费va影院高清| 国产日韩欧美综合一区| 中文日韩电影网站| 亚洲欧美区自拍先锋| 亚洲国产另类久久久精品极度| 欧美不卡视频一区| 欧美精品午夜| 亚洲国产婷婷香蕉久久久久久99| 久久裸体视频| 性欧美videos另类喷潮| 免费一区二区三区| 欧美日韩国产精品自在自线| 禁断一区二区三区在线| 久久成人免费日本黄色| 亚洲国产精品久久久久婷婷884| 一本大道久久a久久综合婷婷| 亚洲人成在线观看一区二区| 欧美成人精品h版在线观看| 亚洲第一主播视频| 欧美激情在线免费观看| 国产精品蜜臀在线观看| 亚洲久久一区二区| 国产专区综合网| 欧美日韩在线直播| 蜜桃久久精品乱码一区二区| 欧美精品一区二区在线观看| 亚洲国内精品| 欧美精品乱码久久久久久按摩| 夜夜夜精品看看| 欧美日韩情趣电影| 亚洲福利国产精品| 亚洲亚洲精品在线观看| 国产欧美日韩在线观看| 免费欧美在线视频| 欧美激情亚洲自拍| 欧美大尺度在线观看| 欧美日本国产一区| 久久字幕精品一区| 亚洲精品三级| 亚洲高清一二三区| 黑人巨大精品欧美一区二区| 欧美日韩在线综合| 欧美激情2020午夜免费观看| 暖暖成人免费视频| 麻豆成人小视频| 国产精品视频免费一区| 久久一二三四| 裸体一区二区三区| 欧美一区二区三区四区夜夜大片| 黄色成人精品网站| 欧美日韩国产欧美日美国产精品| 国产一区二区在线观看免费播放| 亚洲自拍偷拍麻豆| 亚洲自拍偷拍网址| 影音先锋中文字幕一区| 欧美国产日本在线| 激情视频一区二区三区| 裸体歌舞表演一区二区| 亚洲一区二区网站| 久久精品夜夜夜夜久久| 亚洲国产成人av好男人在线观看| 99热精品在线观看| 欧美国产亚洲精品久久久8v| 亚洲特色特黄| 亚洲精选国产| 欧美在线免费一级片| 国产精品久久久免费| 欧美在线国产| 亚洲欧美日韩一区在线观看| 性久久久久久久| 欧美不卡福利| 亚洲精品国产无天堂网2021| 久久国产精品久久久久久电车| 亚洲在线视频免费观看| 欧美午夜不卡影院在线观看完整版免费| 亚洲三级视频在线观看| 国产欧美日韩精品丝袜高跟鞋| 欧美日韩亚洲国产精品| 亚洲免费视频在线观看| 国产欧美高清| 一区二区三区视频观看| 国产欧美成人| 亚洲黄一区二区| 欧美日韩在线不卡| 国产亚洲精品激情久久| 国产欧美一区二区精品忘忧草| 国产欧美日韩一区二区三区在线观看| 亚洲色图自拍| 精品成人在线观看| 性做久久久久久久久| 亚洲影视九九影院在线观看| 国产午夜精品美女视频明星a级| 国产亚洲精品久久久久久| 久久一区二区三区av| 欧美黑人在线观看| 亚洲一区二区网站| 一区在线视频| 国产精品亚洲网站| 好吊色欧美一区二区三区四区| 欧美精品1区| 欧美日韩精品一区二区三区四区| 国产精品区免费视频| 欧美大秀在线观看| 国产精品青草久久久久福利99| 一区二区三区日韩在线观看| 亚洲黑丝在线| 亚洲在线免费视频| 久久成人精品电影| 日韩一级免费观看| 久久不见久久见免费视频1| 欧美成ee人免费视频| 嫩模写真一区二区三区三州| 在线观看成人av| 美女成人午夜| 亚洲裸体俱乐部裸体舞表演av| 亚洲欧美日产图| 亚洲欧美综合国产精品一区| 久热精品在线视频| 久久九九全国免费精品观看| 国产美女诱惑一区二区| 欧美激情久久久久久| 国产在线精品一区二区夜色| 国产自产女人91一区在线观看| 国产午夜精品久久久久久免费视| 亚洲一区在线视频| 影音国产精品| 亚洲午夜激情网站| 欧美成人一区二区| 亚洲欧美日韩久久精品| 国产精品中文字幕欧美| 欧美高清在线视频| 国产欧美日韩综合一区在线观看| 欧美 亚欧 日韩视频在线| 麻豆精品视频在线| 国产欧美精品日韩区二区麻豆天美| 欧美人交a欧美精品| 欧美在线观看一区| 激情视频一区二区三区| 欧美日本久久| 一本色道婷婷久久欧美| 久久久久青草大香线综合精品| 国产精品国产福利国产秒拍| 久久狠狠婷婷| 国产一区深夜福利| 在线视频国内自拍亚洲视频| 久久亚洲国产精品日日av夜夜| 一区二区视频免费在线观看| 国产在线乱码一区二区三区| 欧美久久久久久久久久| 久久九九久精品国产免费直播| 久久国产66| 亚洲影院色在线观看免费| 亚洲激情视频在线观看| 狂野欧美激情性xxxx| 亚洲一区久久| 亚洲激精日韩激精欧美精品| **网站欧美大片在线观看| 欧美日韩成人在线观看| 欧美日韩和欧美的一区二区| 麻豆成人91精品二区三区| 亚洲欧美变态国产另类| 夜夜爽av福利精品导航| 欧美电影免费观看网站| 久久在线免费视频| 久久午夜色播影院免费高清| 亚洲乱码精品一二三四区日韩在线| 国产视频在线观看一区| 亚洲一区二区视频在线| 在线视频中文亚洲| 亚洲精品网址在线观看| 国内精品美女在线观看| 国产日韩一区二区三区在线播放| 老司机成人网| 中文网丁香综合网| 亚洲人精品午夜| 亚洲国产黄色| 亚洲精品国产精品国产自| 久久夜色精品国产| 国产亚洲精品福利| 欧美日本亚洲| 亚洲理论电影网| 亚洲精品中文字幕女同| 欧美日韩成人综合天天影院| 国产午夜精品理论片a级大结局| 欧美精彩视频一区二区三区| 欧美视频在线观看 亚洲欧| 国产欧美精品| 亚洲一级影院| 欧美国产综合视频| 亚洲在线一区| 日韩亚洲欧美中文三级| 国产乱肥老妇国产一区二| 亚洲国产精品欧美一二99| 在线看片欧美| 国产精品丝袜xxxxxxx| 99视频热这里只有精品免费| 亚洲精品综合在线| 欧美偷拍另类| 亚洲精品国产欧美| 亚洲人成人99网站| 国产欧美日本一区二区三区| 欧美性猛交一区二区三区精品| 亚洲视频综合在线| 一本综合久久| 国产精品拍天天在线| 久久精品综合一区| 国产噜噜噜噜噜久久久久久久久| 久久久综合香蕉尹人综合网| 国产欧美一区二区精品仙草咪| 正在播放欧美一区| 亚洲欧洲日韩女同| 久久久久成人精品免费播放动漫| 亚洲国产综合在线| 亚洲在线黄色| 亚洲视频在线免费观看| ●精品国产综合乱码久久久久| 久久久久国产成人精品亚洲午夜| 欧美一区二区三区视频| 免费h精品视频在线播放| 亚洲精品综合久久中文字幕| 欧美伊久线香蕉线新在线| 米奇777超碰欧美日韩亚洲| 一本色道久久综合亚洲精品婷婷| 亚洲裸体在线观看| 欧美在线免费一级片| 国产精品推荐精品| 久久精品人人爽| 欧美日本免费| 99精品99久久久久久宅男| 欧美网站在线| 国产日韩欧美亚洲一区| 欧美/亚洲一区| 91久久精品美女| 136国产福利精品导航| 在线观看中文字幕亚洲| 亚洲免费视频在线观看| 久久国产精品久久w女人spa| 激情五月综合色婷婷一区二区| 欧美与黑人午夜性猛交久久久| 国产精品久久久久久久久久妞妞| 国产精品影院在线观看| 好吊视频一区二区三区四区| 亚洲女优在线| 女人色偷偷aa久久天堂| 一本大道久久a久久精二百| 一色屋精品视频在线观看网站| 亚洲精品国产拍免费91在线| 欧美亚洲在线| 欧美日本高清一区|