在线观看www成人影院-在线观看www日本免费网站-在线观看www视频-在线观看操-欧美18在线-欧美1级

0
  • 聊天消息
  • 系統(tǒng)消息
  • 評論與回復(fù)
登錄后你可以
  • 下載海量資料
  • 學(xué)習(xí)在線課程
  • 觀看技術(shù)視頻
  • 寫文章/發(fā)帖/加入社區(qū)
會員中心
創(chuàng)作中心

完善資料讓更多小伙伴認(rèn)識你,還能領(lǐng)取20積分哦,立即完善>

3天內(nèi)不再提示

內(nèi)存的基本概念以及操作系統(tǒng)的內(nèi)存管理算法

MCU開發(fā)加油站 ? 來源:LiteOS物聯(lián)網(wǎng)操作系統(tǒng) ? 作者:LiteOS物聯(lián)網(wǎng)操作系 ? 2022-08-18 15:52 ? 次閱讀

本文主要介紹內(nèi)存的基本概念以及操作系統(tǒng)的內(nèi)存管理算法

內(nèi)存的基本概念

內(nèi)存是計(jì)算機(jī)系統(tǒng)中除了處理器以外最重要的資源,用于存儲當(dāng)前正在執(zhí)行的程序和數(shù)據(jù)。內(nèi)存是相對于CPU來說的,CPU可以直接尋址的存儲空間叫做內(nèi)存,CPU需要通過驅(qū)動才能訪問的叫做外存。

ROM RAM Flash

內(nèi)存一般采用半導(dǎo)體存儲單元,分為只讀存儲器(ROM,Read Only Memory)、隨機(jī)存儲器(RAM,Random Access Memory)ROM一般只能讀取不能寫入,掉電后其中的數(shù)據(jù)也不會丟失。RAM既可以從中讀取也可以寫入,但是掉電后其中的數(shù)據(jù)會丟失。內(nèi)存一般指的就是RAM。ROM在嵌入式系統(tǒng)中一般用于存儲BootLoader以及操作系統(tǒng)或者程序代碼或者直接當(dāng)硬盤使用。近年來閃存(Flash)已經(jīng)全面代替了ROM在嵌入式系統(tǒng)中的地位,它結(jié)合了ROM和RAM的長處,不僅具備電子可擦除可編程的特性,而且斷電也不會丟失數(shù)據(jù),同時可以快速讀取數(shù)據(jù)。

兩類內(nèi)存管理方式

內(nèi)存管理模塊管理系統(tǒng)的內(nèi)存資源,它是操作系統(tǒng)的核心模塊之一。主要包括內(nèi)存的初始化、分配以及釋放。

從分配內(nèi)存是否連續(xù),可以分為兩大類。

連續(xù)內(nèi)存管理:

為進(jìn)程分配的內(nèi)存空間是連續(xù)的,但這種分配方式容易形成內(nèi)存碎片(碎片是難以利用的空閑內(nèi)存,通常是小內(nèi)存),降低內(nèi)存利用率。連續(xù)內(nèi)存管理主要分為單一連續(xù)內(nèi)存管理和分區(qū)式內(nèi)存管理兩種。

非連續(xù)內(nèi)存管理:

將進(jìn)程分散到多個不連續(xù)的內(nèi)存空間中,可以減少內(nèi)存碎片,內(nèi)存使用率更高。如果分配的基本單位是頁,則稱為分頁內(nèi)存管理;如果基本單位是段,則稱為分段內(nèi)存管理。

當(dāng)前的操作系統(tǒng),普遍采用非連續(xù)內(nèi)存管理方式。不過因?yàn)榉峙淞6容^大,對于內(nèi)存較小的嵌入式系統(tǒng),一般采用連續(xù)內(nèi)存管理。本文主要對嵌入式系統(tǒng)中常用的連續(xù)內(nèi)存管理的分區(qū)式內(nèi)存管理進(jìn)行介紹。

分區(qū)式內(nèi)存管理

分區(qū)式內(nèi)存管理分為固定分區(qū)和動態(tài)分區(qū)。

固定分區(qū):

事先就把內(nèi)存劃分為若干個固定大小的區(qū)域。分區(qū)大小既可以相等也可以不等。固定分區(qū)易于實(shí)現(xiàn),但是會造成分區(qū)內(nèi)碎片浪費(fèi),而且分區(qū)總數(shù)固定,限制了可以并發(fā)執(zhí)行的進(jìn)程數(shù)量。

動態(tài)分區(qū):

根據(jù)進(jìn)程的實(shí)際需要,動態(tài)地給進(jìn)程分配所需內(nèi)存。

動態(tài)分區(qū)式內(nèi)存管理

1運(yùn)作機(jī)制動態(tài)分區(qū)管理一般采用空閑鏈表法,即基于一個雙向鏈表來保存空閑分區(qū)。對于初始狀態(tài),整個內(nèi)存塊都會被作為一個大的空閑分區(qū)加入到空閑鏈表中。當(dāng)進(jìn)程申請內(nèi)存時,將會從這個空閑鏈表中找到一個大小滿足要求的空閑分區(qū)。如果分區(qū)大于所需內(nèi)存,則從該分區(qū)中拆分出需求大小的內(nèi)存交給進(jìn)程,并將此拆分出的內(nèi)存從空閑鏈表中移除,剩下的內(nèi)存仍然是一個掛在空閑鏈表中的空閑分區(qū)。2數(shù)據(jù)結(jié)構(gòu)

空閑鏈表法有多種數(shù)據(jù)結(jié)構(gòu)實(shí)現(xiàn),這里介紹一種較為簡單的數(shù)據(jù)結(jié)構(gòu)。每個空閑分區(qū)的數(shù)據(jù)結(jié)構(gòu)中包含分區(qū)的大小,以及指向前一個分區(qū)和后一個分區(qū)的指針,這樣就能將各個空閑分區(qū)鏈接成一個雙向鏈表。

8865bf06-1ea3-11ed-ba43-dac502259ad0.png

3內(nèi)存分配算法

First Fit (首次適應(yīng)算法)

First Fit要求空閑分區(qū)鏈表以地址從小到大的順序連接。分配內(nèi)存時,從鏈表的第一個空閑分區(qū)開始查找,將最先能夠滿足要求的空閑分區(qū)分配給進(jìn)程。

Next Fit (循環(huán)首次適應(yīng)算法)

Next Fit由First Fit算法演變而來。分配內(nèi)存時,從上一次剛分配過的空閑分區(qū)的下一個開始查找,直至找到能滿足要求的空閑分區(qū)。查找時會采用循環(huán)查找的方式,即如果直到鏈表最后一個空閑分區(qū)都不能滿足要求,則返回到第一個空閑分區(qū)開始查找。

Best Fit (最佳適應(yīng)算法)

從所有空閑分區(qū)中找出能滿足要求的、且大小最小的空閑分區(qū)。為了加快查找速度,Best Fit算法會把所有空閑分區(qū)按其容量從小到大的順序鏈接起來,這樣第一次找到的滿足大小要求的內(nèi)存必然是最小的空閑分區(qū)。

Worst Fit (最壞適應(yīng)算法)

從所有空閑分區(qū)中找出能滿足要求的、且大小最大的空閑分區(qū)。Worst Fit算法按其容量從大到小的順序鏈接所有空閑分區(qū)。

Two LevelSegregated Fit (TLSF)

使用兩層鏈表來管理空閑內(nèi)存,將空閑分區(qū)大小進(jìn)行分類,每一類用一個空閑鏈表表示,其中的空閑內(nèi)存大小都在某個特定值或者某個范圍內(nèi)。這樣存在多個空閑鏈表,所以又用一個索引鏈表來管理這些空閑鏈表,該表的每一項(xiàng)都對應(yīng)一種空閑鏈表,并記錄該類空閑鏈表的表頭指針。

887ab0c8-1ea3-11ed-ba43-dac502259ad0.png

圖中,第一層鏈表將空閑內(nèi)存塊的大小根據(jù)2的冪進(jìn)行分類。第二層鏈表是具體的每一類空閑內(nèi)存塊按照一定的范圍進(jìn)行線性分段。

比如25這一類,以23即8分為4個內(nèi)存區(qū)間

【25,25+8),

【25+8,25+16),

【25+16,25+24),

【25+24,25+32);

216這一類,以214分為4個小區(qū)間

【216,216+214),

【216+214,216+2*214),

【216+2*214,216+3*214),

【216+3*214,216+4*214)。

同時為了快速檢索到空閑塊,每一層鏈表都有一個bitmap用于標(biāo)記對應(yīng)的鏈表中是否有空閑塊,比如第一層bitmap后3位010,表示25這一類內(nèi)存區(qū)間有空閑塊。對應(yīng)的第二層bitmap為0100表示【25+16,25+24)這個區(qū)間有空閑塊,即下面的52Byte

Buddysystems(伙伴算法)

Segregated Fit算法的變種,具有更好的內(nèi)存拆分和回收合并效率。伙伴算法有很多種類,比如BinaryBuddies,F(xiàn)ibonacci Buddies等。Binary Buddies是最簡單也是最流行的一種,將所有空閑分區(qū)根據(jù)分區(qū)的大小進(jìn)行分類,每一類都是具有相同大小的空閑分區(qū)的集合,使用一個空閑雙向鏈表表示。BinaryBuddies中所有的內(nèi)存分區(qū)都是2的冪次方。

因?yàn)闊o論是已分配的或是空閑的分區(qū),其大小均為 2 的冪次方,即使進(jìn)程申請的內(nèi)存小于分配給它的內(nèi)存塊,多余的內(nèi)存也不會再拆分出來給其他進(jìn)程使用,這樣就容易造成內(nèi)部碎片。

當(dāng)進(jìn)程申請一塊大小為n的內(nèi)存時的分配步驟為:

計(jì)算一個i值,使得2i-1

在空閑分區(qū)大小為2i的空閑鏈表中查找。

如果找到空閑塊,則分配給進(jìn)程。

如果2i的空閑分區(qū)已經(jīng)耗盡,則在分區(qū)大小為2i+1的空閑鏈表中查找。

如果存在2i+1的空閑分區(qū),則將此空閑塊分為相等的兩個分區(qū),這兩分區(qū)就是一對伙伴,其中一塊分配給進(jìn)程,另一塊掛到分區(qū)大小為2i的空閑鏈表中。

如果2i+1的空閑分區(qū)還是不存在,則繼續(xù)查找大小為2i+2的空閑分區(qū)。如果找到,需要進(jìn)行兩次拆分。第一次拆分為兩塊大小為2i+1的分區(qū),一塊分區(qū)掛到大小為2i+1的空閑鏈表中,另一塊分區(qū)繼續(xù)拆分為兩塊大小為2i的空閑分區(qū),一塊分配給進(jìn)程,另一塊掛到大小為2i的空閑鏈表中。

如果2i+2的空閑分區(qū)也找不到,則繼續(xù)查找2i+3,以此類推。

在內(nèi)存回收時,如果待回收的內(nèi)存塊與空閑鏈表中的一塊內(nèi)存互為伙伴,則將它們合并為一塊更大的內(nèi)存塊,如果合并后的內(nèi)存塊在空閑鏈表中還有伙伴,則繼續(xù)合并到不能合并為止,并將合并后的內(nèi)存塊掛到對應(yīng)的空閑鏈表中。

889a54d2-1ea3-11ed-ba43-dac502259ad0.png

下面的表格對上面6種算法的優(yōu)缺點(diǎn)進(jìn)行了比較:

內(nèi)存算法優(yōu)點(diǎn)缺點(diǎn)

First Fit高地址空間大空閑塊被保留低地址空間被不斷拆分,造成碎片;每次都從第一個空閑分區(qū)開始查找,增加了查找時的系統(tǒng)開銷

Next Fit空閑分區(qū)分布比較均勻,算法開銷小缺乏大內(nèi)存空閑塊

Best Fit用最小內(nèi)存滿足要求,保留大內(nèi)存空閑塊每次分配后所拆分出來的剩余空閑內(nèi)存總是最小的,造成許多小碎片,算法開銷大

Worst Fit每次分配后所拆分出來的剩余空閑內(nèi)存仍較大,減少小碎片產(chǎn)生缺乏大內(nèi)存空閑塊,算法開銷大

TLSF查找效率高,時間復(fù)雜度小,碎片問題表現(xiàn)良好內(nèi)存回收時算法復(fù)雜,系統(tǒng)開銷大

Buddy systems內(nèi)部碎片比較嚴(yán)重外部碎片較少

審核編輯:湯梓紅

聲明:本文內(nèi)容及配圖由入駐作者撰寫或者入駐合作網(wǎng)站授權(quán)轉(zhuǎn)載。文章觀點(diǎn)僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場。文章及其配圖僅供工程師學(xué)習(xí)之用,如有內(nèi)容侵權(quán)或者其他違規(guī)問題,請聯(lián)系本站處理。 舉報(bào)投訴
  • cpu
    cpu
    +關(guān)注

    關(guān)注

    68

    文章

    10902

    瀏覽量

    213017
  • ROM
    ROM
    +關(guān)注

    關(guān)注

    4

    文章

    575

    瀏覽量

    85991
  • 內(nèi)存
    +關(guān)注

    關(guān)注

    8

    文章

    3055

    瀏覽量

    74331
  • 操作系統(tǒng)
    +關(guān)注

    關(guān)注

    37

    文章

    6895

    瀏覽量

    123745

原文標(biāo)題:如何高效管理MCU內(nèi)存? 多種分配算法對比

文章出處:【微信號:mcugeek,微信公眾號:MCU開發(fā)加油站】歡迎添加關(guān)注!文章轉(zhuǎn)載請注明出處。

收藏 人收藏

    評論

    相關(guān)推薦

    RT-Thread內(nèi)存管理算法源碼閱讀

    RT-Thread對于內(nèi)存管理主要有三種方式:小內(nèi)存管理算法、slab管理算法和memheap管理算法
    的頭像 發(fā)表于 08-10 16:03 ?1638次閱讀
    RT-Thread<b class='flag-5'>內(nèi)存</b><b class='flag-5'>管理算法</b>源碼閱讀

    【安富萊】【RTX操作系統(tǒng)教程】第18章 內(nèi)存管理

    ,malloc()和free()函數(shù)的執(zhí)行時間是不確定的。 在RTX中,操作系統(tǒng)把連續(xù)的大塊內(nèi)存按分區(qū)來管理。每個分區(qū)中包含整數(shù)個大小相同的內(nèi)存塊。如圖18.1所示:圖18.1
    發(fā)表于 02-03 13:23

    什么是嵌入式操作系統(tǒng)內(nèi)存管理技術(shù)?

    1 概 述內(nèi)存管理操作系統(tǒng)的中心任務(wù)之一。內(nèi)存管理模塊通常是操作系統(tǒng)內(nèi)核的一部分,其主要任務(wù)是
    發(fā)表于 07-30 07:19

    操作系統(tǒng)對于內(nèi)存管理

    操作系統(tǒng)如何有效的管理內(nèi)存便顯得尤為重要。本文講述操作系統(tǒng)對于內(nèi)存管理的過去和現(xiàn)在,
    發(fā)表于 08-07 06:53

    操作系統(tǒng)原理基本概念

    操作系統(tǒng)原理基本概念計(jì)算機(jī)硬件系統(tǒng)組成中央處理器中央處理器是計(jì)算機(jī)的運(yùn)算核心(Core)和控制單元( Control Unit) ,主要包括:運(yùn)算邏輯部件: 一個或多個運(yùn)算器寄存器部件: 包括通用
    發(fā)表于 07-26 07:46

    內(nèi)存基本概念以及操作系統(tǒng)內(nèi)存管理算法

    本文主要介紹內(nèi)存基本概念以及操作系統(tǒng)內(nèi)存管理算法內(nèi)存
    發(fā)表于 01-27 06:08

    RT-Thread系統(tǒng)動態(tài)內(nèi)存堆有哪幾種管理算法

    每種 RTOS 均有內(nèi)存管理機(jī)制,RT-Thread 的內(nèi)存管理分為兩類:動態(tài)內(nèi)存管理
    發(fā)表于 03-31 13:53

    有關(guān)RT-Thread操作系統(tǒng)內(nèi)存管理模塊基本知識簡析

    。  RT-Thread操作系統(tǒng)將內(nèi)核與內(nèi)存管理分開實(shí)現(xiàn),操作系統(tǒng)內(nèi)核僅規(guī)定了必要的內(nèi)存管理函數(shù)
    發(fā)表于 05-11 15:14

    動態(tài)內(nèi)存管理是什么?動態(tài)內(nèi)存管理算法有哪幾種

    使用。RT-Thread 系統(tǒng)為了滿足不同的需求,提供了兩套不同的動態(tài)內(nèi)存 管理算法,分別是小堆內(nèi)存管理算法和 SLAB
    發(fā)表于 08-29 15:23

    嵌入式操作系統(tǒng)內(nèi)存管理技術(shù)的分析與比較

    嵌入式操作系統(tǒng)內(nèi)存管理技術(shù)的分析與比較  1 概 述   內(nèi)存管理操作系統(tǒng)的中心任務(wù)之一
    發(fā)表于 01-14 11:30 ?751次閱讀
    嵌入式<b class='flag-5'>操作系統(tǒng)</b><b class='flag-5'>內(nèi)存</b><b class='flag-5'>管理</b>技術(shù)的分析與比較

    嵌入式操作系統(tǒng)FreeRTOS內(nèi)存如何管理和堆

    嵌入式操作系統(tǒng)FreeRTOS內(nèi)存管理和堆
    的頭像 發(fā)表于 01-10 15:17 ?4819次閱讀
    嵌入式<b class='flag-5'>操作系統(tǒng)</b>FreeRTOS<b class='flag-5'>內(nèi)存</b>如何<b class='flag-5'>管理</b>和堆

    內(nèi)存基本概念以及操作系統(tǒng)內(nèi)存管理算法

    本文主要介紹內(nèi)存基本概念以及操作系統(tǒng)內(nèi)存管理算法。 一、
    的頭像 發(fā)表于 08-14 14:39 ?3939次閱讀

    高效管理MCU內(nèi)存的6種分配算法對比

    本文主要介紹內(nèi)存基本概念以及操作系統(tǒng)內(nèi)存管理算法內(nèi)存
    發(fā)表于 12-03 17:06 ?8次下載
    高效<b class='flag-5'>管理</b>MCU<b class='flag-5'>內(nèi)存</b>的6種分配<b class='flag-5'>算法</b>對比

    如何在MCU上高效地管理內(nèi)存

    本文主要介紹內(nèi)存基本概念以及操作系統(tǒng)內(nèi)存管理算法
    發(fā)表于 02-08 15:29 ?2次下載
    如何在MCU上高效地<b class='flag-5'>管理</b><b class='flag-5'>內(nèi)存</b>?

    Linux內(nèi)核實(shí)現(xiàn)內(nèi)存管理基本概念

    本文概述Linux內(nèi)核實(shí)現(xiàn)內(nèi)存管理基本概念,在了解基本概念后,逐步展開介紹實(shí)現(xiàn)內(nèi)存管理的相關(guān)技
    發(fā)表于 06-23 11:56 ?888次閱讀
    Linux內(nèi)核實(shí)現(xiàn)<b class='flag-5'>內(nèi)存</b><b class='flag-5'>管理</b>的<b class='flag-5'>基本概念</b>
    主站蜘蛛池模板: 四虎最新地址 | 资源在线www天堂 | 综合五月 | 天堂网www天堂在线资源链接 | 午夜精品在线免费观看 | 最近高清免费观看视频 | 亚洲伊人久久大香线蕉影院 | 免费国产h视频在线观看 | 求网址你懂的手机在线观看网站 | 亚洲免费色视频 | 午夜骚片| 李老汉的性生生活2 | 日本xxxxx黄区免费看动漫 | 国产午夜三区视频在线 | brazzers在线| 视频一区二区三区在线观看 | 花怜write. as| 欧美性区| 欧美视频色 | 国产三级毛片视频 | 在线观看黄色一级片 | 曰曰摸天天摸人人看久久久 | 成年午夜一级毛片视频 | 天天碰免费视频 | 黄色日本视频 | 亚洲一成人毛片 | 久久国产午夜精品理论篇小说 | 成熟女人免费一级毛片 | 在线观看免费视频片 | 在线免费观看视频黄 | 国产片在线观看狂喷潮bt天堂 | 免费抓胸吻胸激烈视频网站 | 欧美一级做一级做片性十三 | 国内一国产农村妇女一级毛片 | 久久噜国产精品拍拍拍拍 | 国产一级特黄aaaa大片野外 | 毛片福利 | 天天操天天干天天玩 | 99久久99久久精品免费看子伦 | 国内精品一区二区在线观看 | 婷婷在线观看香蕉五月天 |