一区二区三区三上|欧美在线视频五区|国产午夜无码在线观看视频|亚洲国产裸体网站|无码成年人影视|亚洲AV亚洲AV|成人开心激情五月|欧美性爱内射视频|超碰人人干人人上|一区二区无码三区亚洲人区久久精品

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

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

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

堆和棧的增長(zhǎng)方向?yàn)槭裁赐ǔJ窍喾吹模?/h1>

前言

數(shù)據(jù)結(jié)構(gòu)中,堆(heap)與棧(stack)是兩個(gè)常見(jiàn)的數(shù)據(jù)結(jié)構(gòu),它們的存在都是為了優(yōu)化內(nèi)存,提高使用效率,各有特點(diǎn),理解二者的定義、用法與區(qū)別,能夠利用堆與棧解決很多實(shí)際問(wèn)題。

棧:由操作系統(tǒng)(編譯器)自動(dòng)分配釋放 ,存放函數(shù)的參數(shù)值,局部變量的值等

堆:一般由程序員分配釋放, 若程序員不釋放,程序結(jié)束時(shí)由OS回收

內(nèi)存分配圖

通過(guò)下圖了解常用的堆棧內(nèi)存分配和增長(zhǎng)方向:

圖片


增長(zhǎng)方向及原因

堆(heap)的增長(zhǎng)方向是向上增長(zhǎng),即低地址向高地址增長(zhǎng)。

棧(stack)的增長(zhǎng)方向是向下增長(zhǎng),即高地址向低地址增長(zhǎng)。

堆和棧的增長(zhǎng)方向不一致可以讓空閑的內(nèi)存能最大程度的被使用。

能夠確定棧的起始地址。

從內(nèi)存分配圖來(lái)看,假設(shè)棧(stack)的增長(zhǎng)方向也是向上增長(zhǎng),那么棧空間的起始位置就要事先固定下來(lái),在棧和堆的總內(nèi)存大小確定的時(shí)候,一個(gè)分配多了。另一個(gè)分配少了,在不同程序中內(nèi)存的使用情況不同,有些棧用的多,有些堆用的多。

所以就很有可能出現(xiàn)這種情況:一個(gè)程序因?yàn)闂R绯龆罎⒌臅r(shí)候,其實(shí)它還有大量閑置的堆空間沒(méi)有被使用,但是我們卻無(wú)法使用這些閑置的堆空間。所以最好的辦法就是讓堆和棧一個(gè)向上漲,一個(gè)向下漲,這樣它們就可以最大程度地共用這塊剩余的地址空間,達(dá)到利用率的最大化!

并且在棧和堆的總內(nèi)存大小已經(jīng)確定的情況下,不用考慮程序中堆棧的不同使用情況下就能先確定棧的起始地址。

當(dāng)然,現(xiàn)在的有些芯片在編譯時(shí)可以指定棧的增長(zhǎng)方向,不過(guò)常用的還是向下增長(zhǎng)。

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

    關(guān)注

    8

    文章

    3117

    瀏覽量

    75139
  • 數(shù)據(jù)結(jié)構(gòu)

    關(guān)注

    3

    文章

    573

    瀏覽量

    40684
  • STACK
    +關(guān)注

    關(guān)注

    0

    文章

    14

    瀏覽量

    3025
收藏 人收藏
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

    評(píng)論

    相關(guān)推薦
    熱點(diǎn)推薦

    差動(dòng)放大器通常是應(yīng)用在什么場(chǎng)合?

    請(qǐng)問(wèn)下差動(dòng)放大器通常是應(yīng)用在什么場(chǎng)合?
    發(fā)表于 09-19 06:35

    STM32 大小端模式 與 堆棧及其增長(zhǎng)方向分析

    各個(gè)全局變量和靜態(tài)變量.的生長(zhǎng)方向,都是向上的.在程序里面,所有的內(nèi)存分為:+. 只是他們各自的起始地址和增長(zhǎng)方向不同,他們沒(méi)有一個(gè)固
    發(fā)表于 02-10 10:28

    STM32堆棧增長(zhǎng)方向問(wèn)題

    STM32的堆棧增長(zhǎng)方向是從高地址往低地址增長(zhǎng)的,這樣的話(huà)底應(yīng)該是高地址咯。而下圖的底卻是低地址,查了很多資料,感覺(jué)都很矛盾。像INT8UOSTaskCreateExt 的第三個(gè)參
    發(fā)表于 04-20 04:36

    UCOSIII任務(wù)堆棧和STM32堆棧增長(zhǎng)方向是否一致?

    的原子哥視頻,發(fā)現(xiàn)視頻里這塊兒沒(méi)講,UCOS里的堆棧方向是向上增長(zhǎng),而32里是向下[摘自原子哥],這樣會(huì)不會(huì)沖突呢?我所嘗試的理解:這兩個(gè)堆棧占用的是互不相關(guān)的兩個(gè)存儲(chǔ)空間////@發(fā)燒友 @mygod @Admin @偉好好學(xué)習(xí)
    發(fā)表于 04-23 03:51

    MCU空間和空間的相關(guān)資料分享

    stack 空間 heap 空間存儲(chǔ)函數(shù)參數(shù)和局部變量,所需空間由系統(tǒng)自動(dòng)分配,回收也由系統(tǒng)管理,無(wú)需人工干預(yù)存儲(chǔ)動(dòng)態(tài)分配的內(nèi)存塊,分配和釋放空間均由程序員控制,有可能產(chǎn)生內(nèi)存泄漏嚴(yán)格后進(jìn)先出
    發(fā)表于 11-03 08:54

    的區(qū)別是什么

    在回答完進(jìn)程的虛擬地址空間布局之后(上一篇),面試官可能抓住深入展開(kāi)。的區(qū)別①管理方式:由編譯器自動(dòng)管理;
    發(fā)表于 12-22 07:26

    什么是?什么是

    ,程序執(zhí)行過(guò)程中溢出,極大可能的影響程序、系統(tǒng)的穩(wěn)定,嚴(yán)重時(shí)會(huì)造成程序、系統(tǒng)的崩潰,所以堆棧溢出檢測(cè)十分重要且必要。什么是,什么是
    發(fā)表于 12-22 06:09

    放大電路的靜態(tài)工作點(diǎn)通常是指?

    放大電路的靜態(tài)工作點(diǎn)通常是指?
    發(fā)表于 01-27 13:37

    四軸的姿態(tài)進(jìn)行采樣用通常是用什么濾波算法進(jìn)行濾波的?

    四軸的姿態(tài)進(jìn)行采樣用通常是用什么濾波算法進(jìn)行濾波的
    發(fā)表于 10-09 06:42

    連接器通常是EMI問(wèn)題

    在減少EMI問(wèn)題時(shí),大多數(shù)同軸電纜表現(xiàn)相同。它們都是普通電流的良好天線,可以輻射并通過(guò)FCC認(rèn)證類(lèi)型測(cè)試。電纜不是EMC測(cè)試失敗的主要來(lái)源,通常是連接器。 如果有任何凈電流或常見(jiàn)電流一根電纜,通過(guò)
    的頭像 發(fā)表于 11-10 14:58 ?750次閱讀

    光在一個(gè)方向上傳播的軌跡與在相反方向上傳播的軌跡相同嗎

    光的傳播通常是互換的,這意味著光在一個(gè)方向上傳播的軌跡,與在相反方向上傳播光的軌跡相同。
    的頭像 發(fā)表于 03-27 16:52 ?2372次閱讀

    我們習(xí)以為常的IIC通常是什么樣子?資料下載

    電子發(fā)燒友網(wǎng)為你提供我們習(xí)以為常的IIC通常是什么樣子?資料下載的電子資料下載,更有其他相關(guān)的電路圖、源代碼、課件教程、中文資料、英文資料、參考設(shè)計(jì)、用戶(hù)指南、解決方案等資料,希望可以幫助到廣大的電子工程師們。
    發(fā)表于 03-29 08:40 ?6次下載
    我們習(xí)以為常的IIC<b class='flag-5'>通常是</b>什么樣子?資料下載

    什么是內(nèi)存?內(nèi)存是如何分配的?

    在一般的編譯系統(tǒng)中,內(nèi)存的分配方向內(nèi)存是相反的。當(dāng)內(nèi)存從高地址向低地址增長(zhǎng)的時(shí)候,
    的頭像 發(fā)表于 07-05 17:58 ?1w次閱讀

    用C語(yǔ)言如何判斷增長(zhǎng)方向

    畢竟堆棧也就是內(nèi)存,自然就可以通過(guò)堆棧的分配過(guò)程取出所分配的內(nèi)存地址來(lái)比較判斷,而C語(yǔ)言可以方便的訪問(wèn)內(nèi)存,也就比較容易判斷當(dāng)前處理器中堆棧指針的增長(zhǎng)方向了。
    的頭像 發(fā)表于 07-28 11:23 ?2801次閱讀
    用C語(yǔ)言如何判斷<b class='flag-5'>棧</b>的<b class='flag-5'>增長(zhǎng)方向</b>呢

    傳統(tǒng)封裝通常是指什么?包括哪些封裝形式?

    傳統(tǒng)封裝通常是指先將晶片切割成單個(gè)芯片再進(jìn)行封裝的工藝形式,主要包含SIP、DIP、SOP、SOT、TO、QFP、QFN、DFN、BGA 等封裝形式。
    的頭像 發(fā)表于 02-15 17:37 ?5913次閱讀