欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

C++中堆內(nèi)存和棧內(nèi)存區(qū)別小結(jié)

 更新時間:2025年07月11日 10:22:42   作者:晚夜微雨問海棠呀  
在C++中,堆和棧是兩種核心的內(nèi)存管理區(qū)域,用于存儲不同類型的數(shù)據(jù),它們在分配方式、生命周期、大小限制、性能等方面有顯著差異,下面就來介紹一下具體的差異

在 C++ 中,堆(Heap)和棧(Stack)是兩種核心的內(nèi)存管理區(qū)域,用于存儲不同類型的數(shù)據(jù)。它們在分配方式、生命周期、大小限制、性能等方面有顯著差異,理解這些差異對編寫高效且安全的代碼至關(guān)重要。

1. 分配方式與管理機(jī)制

  • 棧內(nèi)存
    由編譯器自動分配和釋放,無需程序員干預(yù)。
    當(dāng)函數(shù)被調(diào)用時,棧會為函數(shù)的局部變量、參數(shù)、返回地址等分配內(nèi)存(壓棧);函數(shù)返回時,這些內(nèi)存會被自動釋放(彈棧)。

    典型場景:

    void func() {
        int a = 10;       // 棧上分配
        char str[20];     // 棧上分配(數(shù)組)
    }  // 函數(shù)結(jié)束,a 和 str 自動釋放
    
  • 堆內(nèi)存
    由程序員手動申請和釋放(通過 new/malloc 申請,delete/free 釋放)。
    內(nèi)存的生命周期完全由程序員控制,若未正確釋放會導(dǎo)致內(nèi)存泄漏。

    典型場景:

    void func() {
        int* p = new int(20);   // 堆上分配
        char* str = (char*)malloc(100);  // 堆上分配
    }  // 函數(shù)結(jié)束,p 和 str 指向的堆內(nèi)存未釋放(內(nèi)存泄漏)
    

2. 生命周期與作用域

棧內(nèi)存
生命周期與作用域嚴(yán)格綁定。例如:

示例:

void func() {
    int x = 0;  // 棧上分配,作用域從定義到函數(shù)結(jié)束
    if (true) {
        int y = 1;  // 棧上分配,作用域到 if 塊結(jié)束
    }  // y 銷毀
}  // x 銷毀
  • 函數(shù)內(nèi)的局部變量在函數(shù)返回時銷毀;
  • 塊級作用域(如 if/for 內(nèi)的變量)在塊結(jié)束時銷毀。

堆內(nèi)存
生命周期與作用域無關(guān),僅取決于是否顯式釋放。即使申請堆內(nèi)存的函數(shù)已返回,只要未調(diào)用 delete/free,堆內(nèi)存仍然存在(可被其他函數(shù)訪問)。

示例:

int* create_int() {
    int* p = new int(100);  // 堆上分配
    return p;  // 函數(shù)返回,但 p 指向的堆內(nèi)存仍存在
}

void use_int() {
    int* ptr = create_int();
    *ptr = 200;  // 仍可訪問堆內(nèi)存
    delete ptr;  // 手動釋放
}

3. 大小限制與內(nèi)存容量

棧內(nèi)存
大小非常有限,通常由操作系統(tǒng)或編譯器設(shè)定(如 Windows 默認(rèn)棧大小約 1MB,Linux 約 8MB)。
若分配的棧內(nèi)存超過限制(如定義過大的局部數(shù)組),會導(dǎo)致棧溢出(Stack Overflow),程序崩潰。

示例風(fēng)險(xiǎn):

void func() {
    char buffer[1024 * 1024];  // 1MB 數(shù)組(可能超過棧大小)
}  // 運(yùn)行時可能棧溢出

堆內(nèi)存
大小受限于物理內(nèi)存和虛擬內(nèi)存,通常遠(yuǎn)大于棧。理論上,只要系統(tǒng)有足夠空閑內(nèi)存,就可以申請堆空間(但受進(jìn)程地址空間限制)。

示例:

void func() {
    char* buffer = new char[1024 * 1024 * 100];  // 100MB 堆內(nèi)存(若系統(tǒng)允許)
    // ...
    delete[] buffer;
}

4. 性能與訪問速度

  • 棧內(nèi)存
    分配和釋放極快(僅需移動棧指針),且內(nèi)存是連續(xù)的(??臻g由系統(tǒng)管理,無碎片)。
    局部變量的訪問速度也更快(通過寄存器直接定位)。

  • 堆內(nèi)存
    分配和釋放較慢(需調(diào)用內(nèi)存管理算法查找空閑塊、更新內(nèi)存表等)。
    頻繁申請/釋放可能導(dǎo)致內(nèi)存碎片(空閑內(nèi)存被分割為小片段,無法利用),進(jìn)一步降低性能。

5. 內(nèi)存地址與增長方向

  • 棧內(nèi)存
    地址從高到低增長(向內(nèi)存低地址方向擴(kuò)展)。例如,函數(shù)調(diào)用時,新的棧幀會覆蓋低地址空間。

  • 堆內(nèi)存
    地址從低到高增長(向內(nèi)存高地址方向擴(kuò)展)。例如,連續(xù)申請堆內(nèi)存時,新的內(nèi)存塊地址通常比前一個大。

6. 典型應(yīng)用場景

場景棧內(nèi)存堆內(nèi)存
小對象/短生命周期數(shù)據(jù)函數(shù)局部變量、臨時變量大對象(如大數(shù)組、結(jié)構(gòu)體)
需跨作用域訪問的數(shù)據(jù)無法實(shí)現(xiàn)(隨作用域銷毀)動態(tài)分配的對象(如類實(shí)例、容器)
內(nèi)存管理復(fù)雜度無(自動管理)高(需手動釋放,易出錯)

總結(jié):如何選擇?

  • 優(yōu)先用棧:小對象、生命周期短、無需跨作用域訪問的數(shù)據(jù)(如局部變量)。
  • 必須用堆:大對象、需長期存在的數(shù)據(jù)(如全局狀態(tài)、容器存儲的元素)。
  • 注意風(fēng)險(xiǎn):棧溢出(避免過大局部變量)、堆泄漏(確保 new/mallocdelete/free 成對)。

現(xiàn)代 C++ 中,推薦用智能指針(如 std::unique_ptr、std::shared_ptr)管理堆內(nèi)存,自動釋放以避免泄漏。

到此這篇關(guān)于C++中堆內(nèi)存和棧內(nèi)存區(qū)別小結(jié)的文章就介紹到這了,更多相關(guān)C++ 堆內(nèi)存和棧內(nèi)存內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • C語言庫函數(shù)中qsort()的用法

    C語言庫函數(shù)中qsort()的用法

    大家好,本篇文章主要講的是C語言庫函數(shù)中qsort()的用法,感興趣的同學(xué)趕快來看一看吧,對你有幫助的話記得收藏一下,方便下次瀏覽
    2021-12-12
  • 帶你了解C語言的數(shù)據(jù)的存儲

    帶你了解C語言的數(shù)據(jù)的存儲

    這篇文章主要為大家詳細(xì)介紹了C語言的數(shù)據(jù)的存儲,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下,希望能給你帶來幫助
    2021-08-08
  • C++詳細(xì)講解print緩沖區(qū)的刷新

    C++詳細(xì)講解print緩沖區(qū)的刷新

    這篇文章主要介紹了print緩沖區(qū)刷新問題,實(shí)現(xiàn)代碼簡單易懂,具有很好的參考價(jià)值,希望對大家有所幫助,需要的朋友可以參考下
    2022-05-05
  • 面向?qū)ο笕筇匦缘囊饬x講解

    面向?qū)ο笕筇匦缘囊饬x講解

    今天小編就為大家分享一篇關(guān)于面向?qū)ο笕筇匦缘囊饬x講解,小編覺得內(nèi)容挺不錯的,現(xiàn)在分享給大家,具有很好的參考價(jià)值,需要的朋友一起跟隨小編來看看吧
    2018-12-12
  • 關(guān)于嘗試開發(fā)PHP的MYSQL擴(kuò)展的使用

    關(guān)于嘗試開發(fā)PHP的MYSQL擴(kuò)展的使用

    本篇文章小編將為大家介紹,關(guān)于嘗試開發(fā)PHP的MYSQL擴(kuò)展的使用,需要的朋友可以參考一下
    2013-04-04
  • string居然也可以用<<和>>

    string居然也可以用<<和>>

    今天小編就為大家分享一篇關(guān)于string居然也可以用<<和>>,小編覺得內(nèi)容挺不錯的,現(xiàn)在分享給大家,具有很好的參考價(jià)值,需要的朋友一起跟隨小編來看看吧
    2019-04-04
  • C++語言pow函數(shù)的具體使用

    C++語言pow函數(shù)的具體使用

    本文主要介紹了C++語言pow函數(shù)的具體使用,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2023-03-03
  • C++ normal_distribution高斯正態(tài)分布函數(shù)的用法示例

    C++ normal_distribution高斯正態(tài)分布函數(shù)的用法示例

    高斯分布也稱為正態(tài)分布(normal distribution),常用的成熟的生成高斯分布隨機(jī)數(shù)序列的方法由Marsaglia和Bray在1964年提出,這篇文章主要給大家介紹了關(guān)于C++ normal_distribution高斯正態(tài)分布函數(shù)用法的相關(guān)資料,需要的朋友可以參考下
    2021-07-07
  • C++結(jié)構(gòu)體字節(jié)對齊示例

    C++結(jié)構(gòu)體字節(jié)對齊示例

    這篇文章主要為大家介紹了C++結(jié)構(gòu)體字節(jié)對齊示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2022-06-06
  • c++ 中vector 常見用法

    c++ 中vector 常見用法

    這篇文章主要給大家分享的是c++ 中vector 常見用法,,vector有兩個參數(shù),一個是size,表示當(dāng)前vector容器內(nèi)存儲的元素個數(shù),一個是capacity,表示當(dāng)前vector在內(nèi)存中申請的這片區(qū)域所能容納的元素個數(shù),下面來看看文章的詳細(xì)內(nèi)容,需要的朋友可以參考一下
    2021-11-11

最新評論