資料介紹
1 Android系統(tǒng)概述
Android是Google(谷歌)公司開(kāi)發(fā)的一款專門為移動(dòng)設(shè)備打造的操作系統(tǒng)。2005年谷歌公司收購(gòu)Android Inc公司后,于2007年研發(fā)了基于Linux的操作系統(tǒng)Android。2008年,TMobile與HTC公司共同研發(fā)了第一款A(yù)ndroid手機(jī)——HTC G1。Android的發(fā)展速度非常驚人,僅僅3年便超過(guò)了Symbian系統(tǒng),并且有強(qiáng)大的OEM支持以及眾多的開(kāi)發(fā)者。
Android基于Linux平臺(tái),主要由操作系統(tǒng)、中間件、用戶界面和應(yīng)用軟件組成。采用的是軟件堆棧的結(jié)構(gòu),操作系統(tǒng)的底層僅提供最基本的系統(tǒng)功能。在Android系統(tǒng)中,基本上使用的是標(biāo)準(zhǔn)的Linux2.6內(nèi)核,但是Google為了讓Android更適合移動(dòng)手持設(shè)備,對(duì)Linux內(nèi)核進(jìn)行了各種優(yōu)化和增強(qiáng)。除了Linux的通用代碼外,主要包含體系結(jié)構(gòu)和處理器、Android特定的驅(qū)動(dòng)程序和標(biāo)準(zhǔn)的設(shè)備驅(qū)動(dòng)程序3個(gè)方面的內(nèi)容。Android對(duì)Linux內(nèi)核的增強(qiáng)主要包括Alarm(硬件鬧鐘)、Ashmem(匿名內(nèi)存共享)、Low Memory Killer(低內(nèi)存管理)、Logger(日志管理)等。本文將集中分析Android的內(nèi)存管理,因?yàn)锳ndroid系統(tǒng)是在Linux系統(tǒng)的基礎(chǔ)上發(fā)展起來(lái)的,所以在介紹Linux基本的內(nèi)存管理的基礎(chǔ)上對(duì)Android的內(nèi)存管理進(jìn)行研究。
2 Linux內(nèi)存管理
在內(nèi)存管理方面,Linux系統(tǒng)新舊兩個(gè)版本(2.6之前和之后)之間有很大的不同。由于Android系統(tǒng)是基于Linux2.6.x內(nèi)核的,本文主要介紹Linux2.6在內(nèi)存管理方面的基本內(nèi)容。
2.1 反向映射機(jī)制
Linux2.6引入了基于對(duì)象的反向映射機(jī)制,這種方法為物理頁(yè)面設(shè)置一個(gè)用于反向映射的鏈表,但是鏈表上的節(jié)點(diǎn)并不是引用了該物理頁(yè)面的所有頁(yè)表項(xiàng),而是相應(yīng)的虛擬內(nèi)存區(qū)域(vm_area_struct結(jié)構(gòu))。虛擬內(nèi)存區(qū)域通過(guò)內(nèi)存描述符(mm_struct結(jié)構(gòu))找到頁(yè)全局目錄,從而找到相應(yīng)的頁(yè)表項(xiàng)。相對(duì)于前一種方法來(lái)說(shuō),用于表示虛擬內(nèi)存區(qū)域的描述符比用于表示頁(yè)面的描述符要少得多,所以遍歷后邊這種反向映射鏈表所消耗的時(shí)間也會(huì)少很多。
page結(jié)構(gòu)中與基于對(duì)象的反向映射相關(guān)的關(guān)鍵字段有兩個(gè):_mapcount和mapping。基于對(duì)象的反向映射的實(shí)現(xiàn)如下:
struct page{
atomic_t_mapcount;
union{
……
struct{
……
struct address_space*mapping;
};
};
字段_mapcount表明共享該物理頁(yè)面的頁(yè)表項(xiàng)的數(shù)目,該計(jì)數(shù)器可用于快速檢查該頁(yè)面除所有者之外有多少使用者在使用,初始值是-1,每增加一個(gè)使用者,該計(jì)數(shù)器加1。
字段mapping用于區(qū)分匿名頁(yè)面和基于文件映射的頁(yè)面。如果該字段的最低位置被置位,那么該字段包含的是指向anon_vma結(jié)構(gòu)(用于匿名頁(yè)面)的指針;否則,該字段包含指向address_space結(jié)構(gòu)的指針(用于基于文件映射的頁(yè)面)。
2.2 Linux頁(yè)面回收
Linux中頁(yè)面回收主要通過(guò)兩種方式觸發(fā):一種是由“內(nèi)存嚴(yán)重不足”事件觸發(fā);另一種是由后臺(tái)進(jìn)程kswapd觸發(fā),該進(jìn)程周期性地運(yùn)行,一旦檢測(cè)到內(nèi)存不足,就會(huì)觸發(fā)頁(yè)面回收操作。這里主要介紹shrink_zone()函數(shù),此函數(shù)是Linux操作系統(tǒng)實(shí)現(xiàn)頁(yè)面回收的最核心的函數(shù)之一,它實(shí)現(xiàn)了對(duì)一個(gè)內(nèi)存區(qū)域的頁(yè)面進(jìn)行回收的功能。該函數(shù)主要做了兩件事:
① 將某些頁(yè)面從active鏈表移到inactive鏈表,這是由函數(shù)shrink_active_list()實(shí)現(xiàn)的;
② 從inactive鏈表中選定一定數(shù)目的頁(yè)面,將其放到一個(gè)臨時(shí)鏈表中,這由函數(shù)shrink_inactive_list()完成。
該函數(shù)最終會(huì)調(diào)用shrink_page_list()去回收這些頁(yè)面。
2.3 OOMKiller機(jī)制
OOM(Out of Memory)是標(biāo)準(zhǔn)Linux內(nèi)核(kernel)的一種內(nèi)存管理機(jī)制,當(dāng)系統(tǒng)內(nèi)存耗盡時(shí),OOM會(huì)選擇性的殺掉一些進(jìn)程以求釋放一些內(nèi)存。
Linux在2.6.36內(nèi)核中修正了OOMKiller的行為,跟之前的OOMKiller相比,主要體現(xiàn)在3個(gè)方面:第一,將物理內(nèi)存頁(yè)面的使用作為基準(zhǔn)而不是虛擬地址空間的大小;第二,導(dǎo)出用戶策略的控制權(quán);第三,內(nèi)核有了一個(gè)簡(jiǎn)單而合理的默認(rèn)策略。
Linux下有3種Overcommit的策略:0,啟發(fā)式策略;1,永遠(yuǎn)允許Overcommit,這種策略適合那些不能承受內(nèi)存分配失敗的應(yīng)用;2,永遠(yuǎn)禁止Overcommit,這種策略下系統(tǒng)所能分配的內(nèi)存不會(huì)超過(guò)swap+RAM*系數(shù)。在Linux系統(tǒng)中,只要存在Overcommit,就可能會(huì)有OOMKiller跳出來(lái)。當(dāng)OOMKiller跳出來(lái)的時(shí)候,期望它可以殺掉沒(méi)用的且耗內(nèi)存多的程序,這就需要一個(gè)選擇目標(biāo)的策略。Linux下這個(gè)選擇目標(biāo)的策略也在隨著內(nèi)核的改進(jìn)不斷的演化。在Linux下每個(gè)進(jìn)程都會(huì)有個(gè)OOM權(quán)重,在/proc/《pid》/oom_adj中,取值是-17~+15,取值越高,越容易被殺掉。用戶可以通過(guò)設(shè)置這些值來(lái)影響OOMKiller作出決策。這個(gè)值是系統(tǒng)綜合進(jìn)程的內(nèi)存消耗量、CPU時(shí)間、存活時(shí)間和oom_adj計(jì)算出的,消耗內(nèi)存越多分值就會(huì)越高。除此之外,Linux在計(jì)算進(jìn)程的內(nèi)存消耗的時(shí)候,會(huì)將子進(jìn)程所耗內(nèi)存的一半同時(shí)算到父進(jìn)程中。
3 Android的低內(nèi)存管理
Android是一個(gè)多任務(wù)系統(tǒng),當(dāng)啟動(dòng)一個(gè)程序時(shí)會(huì)消耗一定的時(shí)間。為了加快運(yùn)行速度,當(dāng)退出一個(gè)程序時(shí),Android并不會(huì)立即殺掉它,這樣當(dāng)用戶重新運(yùn)行該程序時(shí),可以很快地啟動(dòng)。但隨著系統(tǒng)中保留的程序越來(lái)越多,內(nèi)存肯定會(huì)出現(xiàn)不足,此時(shí)就有了Android的低內(nèi)存管理(Low Memory Killer)機(jī)制。
3.1 Low Memory Killer機(jī)制
Low Memory Killer是在標(biāo)準(zhǔn)Linux kernel的OOM基礎(chǔ)上修改而來(lái)的一種內(nèi)存管理機(jī)制,基于oom_adj和占用內(nèi)存的大小來(lái)選擇Bad進(jìn)程。對(duì)應(yīng)于每個(gè)oom_adj都有一個(gè)空閑內(nèi)存的閾值,Android kernel每隔一段時(shí)間會(huì)檢查當(dāng)前空閑內(nèi)存是否低于某個(gè)閾值。如果是,則殺死oom_adj最大的Bad進(jìn)程。如有兩個(gè)以上的Bad進(jìn)程oom_adj相同,則殺死其中占用內(nèi)存最多的進(jìn)程。
3.2 Low Memory Killer的實(shí)現(xiàn)
Low Memory Killer是以內(nèi)核驅(qū)動(dòng)的形式實(shí)現(xiàn)的,該實(shí)現(xiàn)位于drivers/misc/lowmemorykiller.c中,通過(guò)注冊(cè)Cache Shrinker實(shí)現(xiàn)。Cache Shrinker是標(biāo)準(zhǔn)Linux kernel回收頁(yè)面的一種機(jī)制,它由內(nèi)核線程kswapd監(jiān)控,當(dāng)空閑內(nèi)存頁(yè)面不足時(shí),kswapd會(huì)調(diào)用注冊(cè)的Shrinker回調(diào)函數(shù),來(lái)回收內(nèi)存頁(yè)面。lowmem_shrink是這個(gè)驅(qū)動(dòng)的核心實(shí)現(xiàn),當(dāng)內(nèi)存不足時(shí)就會(huì)調(diào)用lowmem_shrink方法來(lái)殺掉某些內(nèi)存。lowmem_shrink用兩個(gè)數(shù)組作為選擇Bad進(jìn)程的依據(jù),定義如下:
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保存空閑內(nèi)存的閾值,單位是一個(gè)頁(yè)面4 KB,lowmem_adj保存每個(gè)閾值對(duì)應(yīng)的優(yōu)先級(jí)。lowmem_shrink首先計(jì)算當(dāng)前空閑內(nèi)存的大小,如果小于某個(gè)閾值,則以該閾值對(duì)應(yīng)的優(yōu)先級(jí)為基準(zhǔn),遍歷各個(gè)進(jìn)程,計(jì)算每個(gè)進(jìn)程占用內(nèi)存的大小,找出優(yōu)先級(jí)大于基準(zhǔn)優(yōu)先級(jí)的進(jìn)程,在這些進(jìn)程中選擇優(yōu)先級(jí)最大的殺死。如果優(yōu)先級(jí)相同,則選擇占用內(nèi)存最多的進(jìn)程。lowmem_shrink殺死進(jìn)程的方法是向進(jìn)程發(fā)送一個(gè)不可以忽略或阻塞的SIGKILL信號(hào):force_sig(SIGKILL,selected)。
Android是Google(谷歌)公司開(kāi)發(fā)的一款專門為移動(dòng)設(shè)備打造的操作系統(tǒng)。2005年谷歌公司收購(gòu)Android Inc公司后,于2007年研發(fā)了基于Linux的操作系統(tǒng)Android。2008年,TMobile與HTC公司共同研發(fā)了第一款A(yù)ndroid手機(jī)——HTC G1。Android的發(fā)展速度非常驚人,僅僅3年便超過(guò)了Symbian系統(tǒng),并且有強(qiáng)大的OEM支持以及眾多的開(kāi)發(fā)者。
Android基于Linux平臺(tái),主要由操作系統(tǒng)、中間件、用戶界面和應(yīng)用軟件組成。采用的是軟件堆棧的結(jié)構(gòu),操作系統(tǒng)的底層僅提供最基本的系統(tǒng)功能。在Android系統(tǒng)中,基本上使用的是標(biāo)準(zhǔn)的Linux2.6內(nèi)核,但是Google為了讓Android更適合移動(dòng)手持設(shè)備,對(duì)Linux內(nèi)核進(jìn)行了各種優(yōu)化和增強(qiáng)。除了Linux的通用代碼外,主要包含體系結(jié)構(gòu)和處理器、Android特定的驅(qū)動(dòng)程序和標(biāo)準(zhǔn)的設(shè)備驅(qū)動(dòng)程序3個(gè)方面的內(nèi)容。Android對(duì)Linux內(nèi)核的增強(qiáng)主要包括Alarm(硬件鬧鐘)、Ashmem(匿名內(nèi)存共享)、Low Memory Killer(低內(nèi)存管理)、Logger(日志管理)等。本文將集中分析Android的內(nèi)存管理,因?yàn)锳ndroid系統(tǒng)是在Linux系統(tǒng)的基礎(chǔ)上發(fā)展起來(lái)的,所以在介紹Linux基本的內(nèi)存管理的基礎(chǔ)上對(duì)Android的內(nèi)存管理進(jìn)行研究。
2 Linux內(nèi)存管理
在內(nèi)存管理方面,Linux系統(tǒng)新舊兩個(gè)版本(2.6之前和之后)之間有很大的不同。由于Android系統(tǒng)是基于Linux2.6.x內(nèi)核的,本文主要介紹Linux2.6在內(nèi)存管理方面的基本內(nèi)容。
2.1 反向映射機(jī)制
Linux2.6引入了基于對(duì)象的反向映射機(jī)制,這種方法為物理頁(yè)面設(shè)置一個(gè)用于反向映射的鏈表,但是鏈表上的節(jié)點(diǎn)并不是引用了該物理頁(yè)面的所有頁(yè)表項(xiàng),而是相應(yīng)的虛擬內(nèi)存區(qū)域(vm_area_struct結(jié)構(gòu))。虛擬內(nèi)存區(qū)域通過(guò)內(nèi)存描述符(mm_struct結(jié)構(gòu))找到頁(yè)全局目錄,從而找到相應(yīng)的頁(yè)表項(xiàng)。相對(duì)于前一種方法來(lái)說(shuō),用于表示虛擬內(nèi)存區(qū)域的描述符比用于表示頁(yè)面的描述符要少得多,所以遍歷后邊這種反向映射鏈表所消耗的時(shí)間也會(huì)少很多。
page結(jié)構(gòu)中與基于對(duì)象的反向映射相關(guān)的關(guān)鍵字段有兩個(gè):_mapcount和mapping。基于對(duì)象的反向映射的實(shí)現(xiàn)如下:
struct page{
atomic_t_mapcount;
union{
……
struct{
……
struct address_space*mapping;
};
};
字段_mapcount表明共享該物理頁(yè)面的頁(yè)表項(xiàng)的數(shù)目,該計(jì)數(shù)器可用于快速檢查該頁(yè)面除所有者之外有多少使用者在使用,初始值是-1,每增加一個(gè)使用者,該計(jì)數(shù)器加1。
字段mapping用于區(qū)分匿名頁(yè)面和基于文件映射的頁(yè)面。如果該字段的最低位置被置位,那么該字段包含的是指向anon_vma結(jié)構(gòu)(用于匿名頁(yè)面)的指針;否則,該字段包含指向address_space結(jié)構(gòu)的指針(用于基于文件映射的頁(yè)面)。
2.2 Linux頁(yè)面回收
Linux中頁(yè)面回收主要通過(guò)兩種方式觸發(fā):一種是由“內(nèi)存嚴(yán)重不足”事件觸發(fā);另一種是由后臺(tái)進(jìn)程kswapd觸發(fā),該進(jìn)程周期性地運(yùn)行,一旦檢測(cè)到內(nèi)存不足,就會(huì)觸發(fā)頁(yè)面回收操作。這里主要介紹shrink_zone()函數(shù),此函數(shù)是Linux操作系統(tǒng)實(shí)現(xiàn)頁(yè)面回收的最核心的函數(shù)之一,它實(shí)現(xiàn)了對(duì)一個(gè)內(nèi)存區(qū)域的頁(yè)面進(jìn)行回收的功能。該函數(shù)主要做了兩件事:
① 將某些頁(yè)面從active鏈表移到inactive鏈表,這是由函數(shù)shrink_active_list()實(shí)現(xiàn)的;
② 從inactive鏈表中選定一定數(shù)目的頁(yè)面,將其放到一個(gè)臨時(shí)鏈表中,這由函數(shù)shrink_inactive_list()完成。
該函數(shù)最終會(huì)調(diào)用shrink_page_list()去回收這些頁(yè)面。
2.3 OOMKiller機(jī)制
OOM(Out of Memory)是標(biāo)準(zhǔn)Linux內(nèi)核(kernel)的一種內(nèi)存管理機(jī)制,當(dāng)系統(tǒng)內(nèi)存耗盡時(shí),OOM會(huì)選擇性的殺掉一些進(jìn)程以求釋放一些內(nèi)存。
Linux在2.6.36內(nèi)核中修正了OOMKiller的行為,跟之前的OOMKiller相比,主要體現(xiàn)在3個(gè)方面:第一,將物理內(nèi)存頁(yè)面的使用作為基準(zhǔn)而不是虛擬地址空間的大小;第二,導(dǎo)出用戶策略的控制權(quán);第三,內(nèi)核有了一個(gè)簡(jiǎn)單而合理的默認(rèn)策略。
Linux下有3種Overcommit的策略:0,啟發(fā)式策略;1,永遠(yuǎn)允許Overcommit,這種策略適合那些不能承受內(nèi)存分配失敗的應(yīng)用;2,永遠(yuǎn)禁止Overcommit,這種策略下系統(tǒng)所能分配的內(nèi)存不會(huì)超過(guò)swap+RAM*系數(shù)。在Linux系統(tǒng)中,只要存在Overcommit,就可能會(huì)有OOMKiller跳出來(lái)。當(dāng)OOMKiller跳出來(lái)的時(shí)候,期望它可以殺掉沒(méi)用的且耗內(nèi)存多的程序,這就需要一個(gè)選擇目標(biāo)的策略。Linux下這個(gè)選擇目標(biāo)的策略也在隨著內(nèi)核的改進(jìn)不斷的演化。在Linux下每個(gè)進(jìn)程都會(huì)有個(gè)OOM權(quán)重,在/proc/《pid》/oom_adj中,取值是-17~+15,取值越高,越容易被殺掉。用戶可以通過(guò)設(shè)置這些值來(lái)影響OOMKiller作出決策。這個(gè)值是系統(tǒng)綜合進(jìn)程的內(nèi)存消耗量、CPU時(shí)間、存活時(shí)間和oom_adj計(jì)算出的,消耗內(nèi)存越多分值就會(huì)越高。除此之外,Linux在計(jì)算進(jìn)程的內(nèi)存消耗的時(shí)候,會(huì)將子進(jìn)程所耗內(nèi)存的一半同時(shí)算到父進(jìn)程中。
3 Android的低內(nèi)存管理
Android是一個(gè)多任務(wù)系統(tǒng),當(dāng)啟動(dòng)一個(gè)程序時(shí)會(huì)消耗一定的時(shí)間。為了加快運(yùn)行速度,當(dāng)退出一個(gè)程序時(shí),Android并不會(huì)立即殺掉它,這樣當(dāng)用戶重新運(yùn)行該程序時(shí),可以很快地啟動(dòng)。但隨著系統(tǒng)中保留的程序越來(lái)越多,內(nèi)存肯定會(huì)出現(xiàn)不足,此時(shí)就有了Android的低內(nèi)存管理(Low Memory Killer)機(jī)制。
3.1 Low Memory Killer機(jī)制
Low Memory Killer是在標(biāo)準(zhǔn)Linux kernel的OOM基礎(chǔ)上修改而來(lái)的一種內(nèi)存管理機(jī)制,基于oom_adj和占用內(nèi)存的大小來(lái)選擇Bad進(jìn)程。對(duì)應(yīng)于每個(gè)oom_adj都有一個(gè)空閑內(nèi)存的閾值,Android kernel每隔一段時(shí)間會(huì)檢查當(dāng)前空閑內(nèi)存是否低于某個(gè)閾值。如果是,則殺死oom_adj最大的Bad進(jìn)程。如有兩個(gè)以上的Bad進(jìn)程oom_adj相同,則殺死其中占用內(nèi)存最多的進(jìn)程。
3.2 Low Memory Killer的實(shí)現(xiàn)
Low Memory Killer是以內(nèi)核驅(qū)動(dòng)的形式實(shí)現(xiàn)的,該實(shí)現(xiàn)位于drivers/misc/lowmemorykiller.c中,通過(guò)注冊(cè)Cache Shrinker實(shí)現(xiàn)。Cache Shrinker是標(biāo)準(zhǔn)Linux kernel回收頁(yè)面的一種機(jī)制,它由內(nèi)核線程kswapd監(jiān)控,當(dāng)空閑內(nèi)存頁(yè)面不足時(shí),kswapd會(huì)調(diào)用注冊(cè)的Shrinker回調(diào)函數(shù),來(lái)回收內(nèi)存頁(yè)面。lowmem_shrink是這個(gè)驅(qū)動(dòng)的核心實(shí)現(xiàn),當(dāng)內(nèi)存不足時(shí)就會(huì)調(diào)用lowmem_shrink方法來(lái)殺掉某些內(nèi)存。lowmem_shrink用兩個(gè)數(shù)組作為選擇Bad進(jìn)程的依據(jù),定義如下:
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保存空閑內(nèi)存的閾值,單位是一個(gè)頁(yè)面4 KB,lowmem_adj保存每個(gè)閾值對(duì)應(yīng)的優(yōu)先級(jí)。lowmem_shrink首先計(jì)算當(dāng)前空閑內(nèi)存的大小,如果小于某個(gè)閾值,則以該閾值對(duì)應(yīng)的優(yōu)先級(jí)為基準(zhǔn),遍歷各個(gè)進(jìn)程,計(jì)算每個(gè)進(jìn)程占用內(nèi)存的大小,找出優(yōu)先級(jí)大于基準(zhǔn)優(yōu)先級(jí)的進(jìn)程,在這些進(jìn)程中選擇優(yōu)先級(jí)最大的殺死。如果優(yōu)先級(jí)相同,則選擇占用內(nèi)存最多的進(jìn)程。lowmem_shrink殺死進(jìn)程的方法是向進(jìn)程發(fā)送一個(gè)不可以忽略或阻塞的SIGKILL信號(hào):force_sig(SIGKILL,selected)。
下載該資料的人也在下載
下載該資料的人還在閱讀
更多 >
- 探究車輛統(tǒng)籌信息管理系統(tǒng) 2次下載
- 探究機(jī)動(dòng)車保險(xiǎn)統(tǒng)籌管理系統(tǒng) 0次下載
- Oracle+Timesten內(nèi)存數(shù)據(jù)庫(kù)自動(dòng)數(shù)據(jù)清理機(jī)制探究
- Glibc內(nèi)存管理之Ptmalloc2源代碼分析 24次下載
- 基于內(nèi)存關(guān)聯(lián)分析的內(nèi)存預(yù)拷貝遷移策略 14次下載
- Android電源管理設(shè)計(jì)資料下載
- 鴻蒙內(nèi)核源碼分析: 虛擬內(nèi)存和物理內(nèi)存是怎么管理的 19次下載
- Android系統(tǒng)電源的管理和省電機(jī)制的詳細(xì)資料說(shuō)明
- 基于Android油耗信息管理系統(tǒng) 0次下載
- 基于Android的NFC技術(shù)的移動(dòng)簽到管理系統(tǒng) 23次下載
- Symbian與WinCE內(nèi)存管理技術(shù)分析及對(duì)比 0次下載
- 關(guān)于μC/OS-II實(shí)時(shí)操作系統(tǒng)內(nèi)存管理的改進(jìn)方法分析 0次下載
- μClinux內(nèi)存管理分析
- VxWorks內(nèi)存管理機(jī)制的分析與研究
- 通信設(shè)備中內(nèi)存管理優(yōu)化
- Linux內(nèi)核內(nèi)存管理架構(gòu)解析 686次閱讀
- MMU內(nèi)存管理單元的工作原理和作用 2495次閱讀
- 內(nèi)存的基本概念以及操作系統(tǒng)的內(nèi)存管理算法 1794次閱讀
- Linux內(nèi)存管理體系介紹 1670次閱讀
- xenomai系統(tǒng)中的xnheap管理機(jī)制 1770次閱讀
- Linux內(nèi)存管理之伙伴系統(tǒng) 1335次閱讀
- 嵌入式系統(tǒng)內(nèi)存管理機(jī)制詳解 4552次閱讀
- 如何管理Linux 的內(nèi)存分頁(yè)? 3818次閱讀
- 基于Android系統(tǒng)的高效內(nèi)存方法解析 1179次閱讀
- 一文讀懂 Spark 內(nèi)存管理 974次閱讀
- Android內(nèi)存管理機(jī)制與分析工具 4569次閱讀
- Android性能優(yōu)化之Java內(nèi)存 1008次閱讀
- 基于Linux內(nèi)存管理與Android內(nèi)存分配機(jī)制 6246次閱讀
- LWIP內(nèi)存管理知識(shí)匯總 6951次閱讀
- Linux系統(tǒng)內(nèi)存管理的特點(diǎn)詳解 4048次閱讀
下載排行
本周
- 1TC358743XBG評(píng)估板參考手冊(cè)
- 1.36 MB | 330次下載 | 免費(fèi)
- 2開(kāi)關(guān)電源基礎(chǔ)知識(shí)
- 5.73 MB | 6次下載 | 免費(fèi)
- 3100W短波放大電路圖
- 0.05 MB | 4次下載 | 3 積分
- 4嵌入式linux-聊天程序設(shè)計(jì)
- 0.60 MB | 3次下載 | 免費(fèi)
- 5基于FPGA的光纖通信系統(tǒng)的設(shè)計(jì)與實(shí)現(xiàn)
- 0.61 MB | 2次下載 | 免費(fèi)
- 6基于FPGA的C8051F單片機(jī)開(kāi)發(fā)板設(shè)計(jì)
- 0.70 MB | 2次下載 | 免費(fèi)
- 751單片機(jī)窗簾控制器仿真程序
- 1.93 MB | 2次下載 | 免費(fèi)
- 8基于51單片機(jī)的RGB調(diào)色燈程序仿真
- 0.86 MB | 2次下載 | 免費(fèi)
本月
- 1OrCAD10.5下載OrCAD10.5中文版軟件
- 0.00 MB | 234315次下載 | 免費(fèi)
- 2555集成電路應(yīng)用800例(新編版)
- 0.00 MB | 33564次下載 | 免費(fèi)
- 3接口電路圖大全
- 未知 | 30323次下載 | 免費(fèi)
- 4開(kāi)關(guān)電源設(shè)計(jì)實(shí)例指南
- 未知 | 21548次下載 | 免費(fèi)
- 5電氣工程師手冊(cè)免費(fèi)下載(新編第二版pdf電子書)
- 0.00 MB | 15349次下載 | 免費(fèi)
- 6數(shù)字電路基礎(chǔ)pdf(下載)
- 未知 | 13750次下載 | 免費(fèi)
- 7電子制作實(shí)例集錦 下載
- 未知 | 8113次下載 | 免費(fèi)
- 8《LED驅(qū)動(dòng)電路設(shè)計(jì)》 溫德?tīng)栔?/a>
- 0.00 MB | 6653次下載 | 免費(fèi)
總榜
- 1matlab軟件下載入口
- 未知 | 935054次下載 | 免費(fèi)
- 2protel99se軟件下載(可英文版轉(zhuǎn)中文版)
- 78.1 MB | 537796次下載 | 免費(fèi)
- 3MATLAB 7.1 下載 (含軟件介紹)
- 未知 | 420026次下載 | 免費(fèi)
- 4OrCAD10.5下載OrCAD10.5中文版軟件
- 0.00 MB | 234315次下載 | 免費(fèi)
- 5Altium DXP2002下載入口
- 未知 | 233046次下載 | 免費(fèi)
- 6電路仿真軟件multisim 10.0免費(fèi)下載
- 340992 | 191185次下載 | 免費(fèi)
- 7十天學(xué)會(huì)AVR單片機(jī)與C語(yǔ)言視頻教程 下載
- 158M | 183278次下載 | 免費(fèi)
- 8proe5.0野火版下載(中文版免費(fèi)下載)
- 未知 | 138040次下載 | 免費(fèi)
評(píng)論
查看更多