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

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

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

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

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

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

    典型場(chǎng)景:

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

    典型場(chǎng)景:

    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ù)返回時(shí)銷毀;
  • 塊級(jí)作用域(如 if/for 內(nèi)的變量)在塊結(jié)束時(shí)銷毀。

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

示例:

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

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

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

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

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

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

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

示例:

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

4. 性能與訪問(wèn)速度

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

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

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

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

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

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

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

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

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

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

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

相關(guān)文章

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

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

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

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

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

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

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

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

    今天小編就為大家分享一篇關(guān)于面向?qū)ο笕筇匦缘囊饬x講解,小編覺(jué)得內(nèi)容挺不錯(cuò)的,現(xiàn)在分享給大家,具有很好的參考價(jià)值,需要的朋友一起跟隨小編來(lái)看看吧
    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居然也可以用<<和>>,小編覺(jué)得內(nèi)容挺不錯(cuò)的,現(xiàn)在分享給大家,具有很好的參考價(jià)值,需要的朋友一起跟隨小編來(lái)看看吧
    2019-04-04
  • C++語(yǔ)言pow函數(shù)的具體使用

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

    本文主要介紹了C++語(yǔ)言pow函數(shù)的具體使用,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(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é)對(duì)齊示例

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

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

    c++ 中vector 常見用法

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

最新評(píng)論