RM新时代网站-首页

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

完善資料讓更多小伙伴認識你,還能領取20積分哦,立即完善>

3天內不再提示

堆和棧的增長方向為什么通常是相反的?

汽車電子技術 ? 來源: 大橙子瘋嵌入式 ? 作者:大橙子瘋 ? 2023-02-15 15:08 ? 次閱讀

前言

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

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

堆:一般由程序員分配釋放, 若程序員不釋放,程序結束時由OS回收

內存分配圖

通過下圖了解常用的堆棧內存分配和增長方向:

圖片


增長方向及原因

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

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

堆和棧的增長方向不一致可以讓空閑的內存能最大程度的被使用。

能夠確定棧的起始地址。

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

所以就很有可能出現(xiàn)這種情況:一個程序因為棧溢出而崩潰的時候,其實它還有大量閑置的堆空間沒有被使用,但是我們卻無法使用這些閑置的堆空間。所以最好的辦法就是讓堆和棧一個向上漲,一個向下漲,這樣它們就可以最大程度地共用這塊剩余的地址空間,達到利用率的最大化!

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

當然,現(xiàn)在的有些芯片在編譯時可以指定棧的增長方向,不過常用的還是向下增長。

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

    關注

    8

    文章

    3019

    瀏覽量

    74003
  • 數(shù)據(jù)結構

    關注

    3

    文章

    573

    瀏覽量

    40123
  • STACK
    +關注

    關注

    0

    文章

    13

    瀏覽量

    2794
收藏 人收藏

    評論

    相關推薦

    差動放大器通常是應用在什么場合?

    請問下差動放大器通常是應用在什么場合?
    發(fā)表于 09-19 06:35

    STM32 大小端模式 與 堆棧及其增長方向分析

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

    STM32堆棧增長方向問題

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

    UCOSIII任務堆棧和STM32堆棧增長方向是否一致?

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

    MCU空間和空間的相關資料分享

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

    的區(qū)別是什么

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

    什么是?什么是

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

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

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

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

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

    連接器通常是EMI問題

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

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

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

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

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

    什么是內存?內存是如何分配的?

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

    用C語言如何判斷增長方向

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

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

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