色哟哟视频在线观看-色哟哟视频在线-色哟哟欧美15最新在线-色哟哟免费在线观看-国产l精品国产亚洲区在线观看-国产l精品国产亚洲区久久

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

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

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

什么是堆內(nèi)存與棧內(nèi)存?它們的分配和回收有什么特點(diǎn)?

xCb1_yikoulinux ? 來源:程序喵大人 ? 作者:程序喵大人 ? 2022-07-01 10:33 ? 次閱讀

這篇文章分享一個(gè)面試中經(jīng)常被問到的知識(shí)點(diǎn):堆內(nèi)存和棧內(nèi)存有什么區(qū)別?平時(shí)開發(fā)應(yīng)該使用堆內(nèi)存還是棧內(nèi)存?

要回答這個(gè)問題,我們首先需要知道什么是堆內(nèi)存,什么是棧內(nèi)存,它們的分配和回收有什么特點(diǎn)?

先介紹下棧內(nèi)存:

棧內(nèi)存是為線程留出的臨時(shí)空間,每個(gè)線程都有一個(gè)固定大小的棧空間,而且棧空間存儲(chǔ)的數(shù)據(jù)只能由當(dāng)前線程訪問,所以它是線程安全的。

棧空間的分配和回收是由系統(tǒng)來做的,我們不需要手動(dòng)控制。

當(dāng)一個(gè)函數(shù)調(diào)用時(shí),系統(tǒng)就會(huì)為該函數(shù)的調(diào)用分配棧空間,當(dāng)函數(shù)返回后,系統(tǒng)就會(huì)自動(dòng)回收這塊空間,同理,下次其它函數(shù)調(diào)用和返回,系統(tǒng)還是會(huì)自動(dòng)分配和回收空間。

那它是怎么分配和回收的呢?

可以看這兩個(gè)動(dòng)畫

9455e43c-f75f-11ec-ba43-dac502259ad0.gif

94ae6f6c-f75f-11ec-ba43-dac502259ad0.gif

棧空間的大小是固定的,它有一個(gè)水位線,標(biāo)識(shí)棧空間的分配狀態(tài),水位線里面的表示已經(jīng)分配,然后這個(gè)水位線會(huì)根據(jù)函數(shù)調(diào)用和返回的情況自動(dòng)調(diào)整。

這里可以看到,棧空間的分配和回收非常簡(jiǎn)單,只需要調(diào)整水位線位置就可以了,沒有任何多余操作。

那堆內(nèi)存呢?

我們平時(shí)在C語言C++中使用malloc和new分配的內(nèi)存就是堆內(nèi)存,堆內(nèi)存的一大特點(diǎn)就是大小不固定,可以動(dòng)態(tài)擴(kuò)容,空間由程序員動(dòng)態(tài)分配,更加靈活。

然而,既然有優(yōu)點(diǎn)也必然伴隨著缺點(diǎn)。

第一個(gè)缺點(diǎn)就是它容易產(chǎn)生內(nèi)存泄露,malloc出來的沒有free,new出來的如果沒有delete,都會(huì)產(chǎn)生內(nèi)存泄露,真正項(xiàng)目?jī)?nèi)存泄露產(chǎn)生的情況肯定比這個(gè)復(fù)雜的多。

第二個(gè)缺點(diǎn),容易產(chǎn)生內(nèi)存碎片,在分配和回收時(shí)需要對(duì)很多內(nèi)存碎片進(jìn)行整理,效率較低,具體可以看這個(gè)動(dòng)畫。

94c9bace-f75f-11ec-ba43-dac502259ad0.gif

所以才會(huì)有很多自定義的內(nèi)存分配器,但它肯定還是沒有棧空間分配回收速度快。

第三個(gè)缺點(diǎn),線程不安全,它不像棧內(nèi)存是線程獨(dú)立的,堆內(nèi)存可以被一個(gè)進(jìn)程內(nèi)所有的線程訪問,多線程操作就容易產(chǎn)生問題,很多奇奇怪怪的操作就是這么引起的。

那什么變量存儲(chǔ)在棧上,什么存儲(chǔ)在堆上呢?普通的A a,這種就是都存儲(chǔ)在棧上,當(dāng)使用new和malloc分配的空間會(huì)存儲(chǔ)在堆上,看這個(gè)圖:

94ebba7a-f75f-11ec-ba43-dac502259ad0.jpg

new出來的實(shí)際空間是在堆上分配,然后在棧上開辟一個(gè)指針大小的空間,這個(gè)空間有一個(gè)指針,指向堆上的那塊內(nèi)存,這樣給變量和堆內(nèi)存之間就關(guān)聯(lián)起來了。

那什么情況下使用棧內(nèi)存,什么情況下使用堆內(nèi)存呢?

我整理出來了一個(gè)表,貼在這里:

速度
空間管理 高效,不會(huì)產(chǎn)生碎片 會(huì)產(chǎn)生內(nèi)存碎片
訪問權(quán)限 只能局部變量 可以訪問全局變量
空間大小限制 操作系統(tǒng)限制 沒有特定的限制
內(nèi)存分配 連續(xù) 隨機(jī)分配
分配和釋放 編譯器指令自動(dòng)管理 程序員手動(dòng)管理
開銷
主要問題 空間小 內(nèi)存碎片
靈活性 固定大小 可以resize

這里可以根據(jù)實(shí)際需求來決定使用哪類內(nèi)存。

當(dāng)然,其實(shí)也不用關(guān)注那么多,我一般就是大內(nèi)存使用堆,局部變量小內(nèi)存使用棧。

這里還涉及到很多其它知識(shí)點(diǎn),比如進(jìn)程的內(nèi)存空間布局是怎么樣的,棧空間會(huì)不會(huì)污染、堆內(nèi)存具體是怎么分配和回收的。

具體在我的公眾號(hào)里搜索吧,里面有很多相關(guān)文章。

原文標(biāo)題:堆內(nèi)存和棧內(nèi)存的區(qū)別

文章出處:【微信公眾號(hào):一口Linux】歡迎添加關(guān)注!文章轉(zhuǎn)載請(qǐng)注明出處。

審核編輯:彭靜

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

    關(guān)注

    8

    文章

    3028

    瀏覽量

    74097
  • C語言
    +關(guān)注

    關(guān)注

    180

    文章

    7605

    瀏覽量

    136988
  • 函數(shù)
    +關(guān)注

    關(guān)注

    3

    文章

    4333

    瀏覽量

    62686

原文標(biāo)題:堆內(nèi)存和棧內(nèi)存的區(qū)別

文章出處:【微信號(hào):yikoulinux,微信公眾號(hào):一口Linux】歡迎添加關(guān)注!文章轉(zhuǎn)載請(qǐng)注明出處。

收藏 人收藏

    評(píng)論

    相關(guān)推薦

    談JVM xmx, xms等內(nèi)存相關(guān)參數(shù)合理性設(shè)置

    的,提高內(nèi)存占用(Memory Footprint)就有可能同時(shí)優(yōu)化這兩個(gè)標(biāo)的,這篇文章就來聊聊內(nèi)存相關(guān)內(nèi)容。 內(nèi)存占用一般指應(yīng)用運(yùn)行需要的所有內(nèi)存,包括
    的頭像 發(fā)表于 10-10 14:42 ?556次閱讀

    邏輯內(nèi)存和物理內(nèi)存的區(qū)別

    邏輯內(nèi)存和物理內(nèi)存是計(jì)算機(jī)系統(tǒng)中兩個(gè)重要的概念,它們在計(jì)算機(jī)的運(yùn)行和數(shù)據(jù)處理中起著至關(guān)重要的作用。 1. 物理內(nèi)存(Physical Memory) 物理
    的頭像 發(fā)表于 09-27 15:38 ?723次閱讀

    轉(zhuǎn)載 golang內(nèi)存分配

    Go 的分配采用了類似 tcmalloc 的結(jié)構(gòu).特點(diǎn): 使用一小塊一小塊的連續(xù)內(nèi)存頁, 進(jìn)行分配某個(gè)范圍大小的內(nèi)存需求. 比如某個(gè)連續(xù) 8
    的頭像 發(fā)表于 09-05 14:12 ?274次閱讀
    轉(zhuǎn)載 golang<b class='flag-5'>內(nèi)存</b><b class='flag-5'>分配</b>

    堆棧和內(nèi)存的基本知識(shí)

    本文主要聊聊關(guān)于堆棧的內(nèi)容。包括堆棧和內(nèi)存的基本知識(shí)。常見和堆棧相關(guān)的 bug,如溢出,內(nèi)存泄漏,內(nèi)存
    的頭像 發(fā)表于 08-29 14:10 ?481次閱讀
    堆棧和<b class='flag-5'>內(nèi)存</b>的基本知識(shí)

    如何使用SystemView的監(jiān)控功能

    應(yīng)用中監(jiān)視所有,分析它們的使用情況,并展示收集到的信息,使用戶能夠查看的負(fù)載情況,發(fā)現(xiàn)潛在的內(nèi)存泄漏,跟蹤內(nèi)存使用峰值等等。
    的頭像 發(fā)表于 08-09 18:07 ?823次閱讀
    如何使用SystemView的<b class='flag-5'>堆</b>監(jiān)控功能

    FreeRTOS如何在中斷中調(diào)用內(nèi)存分配函數(shù)?

    最近在玩FreeRTOS,遇到一個(gè)問題,就是不知如何在中斷中調(diào)用內(nèi)存分配函數(shù)。pvPortMalloc函數(shù)中會(huì)調(diào)用xTaskResumeAll,而這個(gè)函數(shù)不能再中斷調(diào)用,所以請(qǐng)問在中斷中進(jìn)行內(nèi)存
    發(fā)表于 05-08 08:25

    你知道嗎? 51單片機(jī)也有動(dòng)態(tài)內(nèi)存分配

    、realloc、free。他們的頭文件在中,所以使用內(nèi)存管理必須包含該頭文件。二、使用方法51單片機(jī)需要使用內(nèi)存管理API必須要手動(dòng)調(diào)用初始化內(nèi)存管理函數(shù):init_
    的頭像 發(fā)表于 04-26 08:10 ?1569次閱讀
    你知道嗎? 51單片機(jī)也有動(dòng)態(tài)<b class='flag-5'>內(nèi)存</b><b class='flag-5'>分配</b>

    C語言內(nèi)存泄漏問題原理

    內(nèi)存泄漏問題只有在使用內(nèi)存的時(shí)候才會(huì)出現(xiàn),內(nèi)存不存在內(nèi)存泄漏問題,因?yàn)?/div>
    發(fā)表于 03-19 11:38 ?530次閱讀
    C語言<b class='flag-5'>內(nèi)存</b>泄漏問題原理

    Linux內(nèi)核內(nèi)存管理之內(nèi)核非連續(xù)物理內(nèi)存分配

    我們已經(jīng)知道,最好將虛擬地址映射到連續(xù)頁幀,從而更好地利用緩存并實(shí)現(xiàn)更低的平均內(nèi)存訪問時(shí)間。然而,如果對(duì)內(nèi)存區(qū)域的請(qǐng)求并不頻繁,那么考慮基于通過連續(xù)線性地址訪問非連續(xù)頁幀的分配方案是有意義的。該模式
    的頭像 發(fā)表于 02-23 09:44 ?993次閱讀
    Linux內(nèi)核<b class='flag-5'>內(nèi)存</b>管理之內(nèi)核非連續(xù)物理<b class='flag-5'>內(nèi)存</b><b class='flag-5'>分配</b>

    Linux內(nèi)核內(nèi)存管理之ZONE內(nèi)存分配

    內(nèi)核中使用ZONE分配器滿足內(nèi)存分配請(qǐng)求。該分配器必須具有足夠的空閑頁幀,以便滿足各種內(nèi)存大小請(qǐng)求。
    的頭像 發(fā)表于 02-21 09:29 ?912次閱讀

    拆解mmap內(nèi)存映射的本質(zhì)!

    mmap 內(nèi)存映射里所謂的內(nèi)存其實(shí)指的是虛擬內(nèi)存,在調(diào)用 mmap 進(jìn)行匿名映射的時(shí)候(比如進(jìn)行內(nèi)存
    的頭像 發(fā)表于 01-24 14:30 ?1773次閱讀
    拆解mmap<b class='flag-5'>內(nèi)存</b>映射的本質(zhì)!

    的區(qū)別和使用注意事項(xiàng)

    是在計(jì)算機(jī)科學(xué)中廣泛使用的兩種數(shù)據(jù)結(jié)構(gòu),它們具有不同的用途和特點(diǎn)的區(qū)別涉及到
    的頭像 發(fā)表于 01-18 17:24 ?2237次閱讀

    glibc malloc內(nèi)存分配器的實(shí)現(xiàn)原理

    內(nèi)存(Heap Memory)是一個(gè)很有意思的領(lǐng)域。你可能和我一樣,也困惑于下述問題很久了。
    的頭像 發(fā)表于 01-17 10:03 ?838次閱讀
    glibc malloc<b class='flag-5'>內(nèi)存</b><b class='flag-5'>分配</b>器的實(shí)現(xiàn)原理

    系統(tǒng)內(nèi)存和運(yùn)行內(nèi)存的區(qū)別

    系統(tǒng)內(nèi)存和運(yùn)行內(nèi)存都是計(jì)算機(jī)中重要的概念,它們在計(jì)算機(jī)的存儲(chǔ)和運(yùn)行方面起著不可或缺的作用。雖然它們與計(jì)算機(jī)存儲(chǔ)和運(yùn)行息息相關(guān),但是它們具有不
    的頭像 發(fā)表于 01-15 16:32 ?3413次閱讀

    Linux內(nèi)核內(nèi)存管理架構(gòu)解析

    內(nèi)存管理子系統(tǒng)可能是linux內(nèi)核中最為復(fù)雜的一個(gè)子系統(tǒng),其支持的功能需求眾多,如頁面映射、頁面分配、頁面回收、頁面交換、冷熱頁面、緊急頁面、頁面碎片管理、頁面緩存、頁面統(tǒng)計(jì)等,而且對(duì)性能也有很高
    的頭像 發(fā)表于 01-04 09:24 ?669次閱讀
    Linux內(nèi)核<b class='flag-5'>內(nèi)存</b>管理架構(gòu)解析
    主站蜘蛛池模板: 日本超A大片在线观看| 亚洲薄码区| 最近的2019中文字幕国语HD| 久久婷婷电影网| 99精彩视频在线观看| 青青国产在线观看视频| 国产精品久久久久一区二区三区 | 精彩国产萝视频在线| 在线亚洲精品国产一区麻豆| 男宿舍里的呻吟h| 国产国语在线播放视频| 亚洲中文无码永久免费| 男女啪啪久久精品亚洲A| 国产99久久九九免费精品无码| 亚洲国产中文字幕在线视频| 乱VODAFONEWIFI熟妇| 动漫成人片| 伊人草| 日本久久中文字幕精品| 国产欧美亚洲综合第一页| 中文字幕在线观看亚洲日韩| 性吧 校园春色| 嗯呐啊唔高H兽交| 久久久性色精品国产免费观看| 打卡中国各地奋斗第一线| 90后性爱视频| 亚洲国产成人久久精品影视| 日韩美女爱爱| 两百磅美女| 久久久久激情免费观看| 久久re热在线视频精6| 俄罗斯老妇女BBXX| 在线日韩欧美一区二区三区| 亚洲免费在线视频| 日韩黄色免费| 青青精品视频国产| 青青伊人精品| 日韩精品久久久久久久电影| 全彩acg无翼乌火影忍者| 青青草原国产在线观看| 日韩精品一区二区亚洲AV观看|