正在閱讀:新手入門(mén):C++中堆內(nèi)存(heap)的概念和操作方法新手入門(mén):C++中堆內(nèi)存(heap)的概念和操作方法

2005-03-02 09:46 出處:PConline 作者:管寧 責(zé)任編輯:huangpeidan
 

  堆內(nèi)存是什么呢?

  我們知道在c/c++中定義的數(shù)組大小必需要事先定義好,他們通常是分配在靜態(tài)內(nèi)存空間或者是在棧內(nèi)存空間內(nèi)的,但是在實(shí)際工作中,我們有時(shí)候卻需要?jiǎng)討B(tài)的為數(shù)組分配大小,在這里c庫(kù)中的malloc.h頭文件中的malloc()函數(shù)就為您解決了問(wèn)題(bc或者是在老的標(biāo)準(zhǔn)中是alloc.h),它的函數(shù)原形是void* malloc(size_t size),在動(dòng)態(tài)開(kāi)辟的內(nèi)存中,在使用完后我們要使用free()函數(shù)來(lái)釋放動(dòng)態(tài)開(kāi)辟的內(nèi)存空間。

  下面我們來(lái)看一個(gè)完整的例子:

#include <iostream
#include <malloc.h> 
 
using namespace std; 
main() 

    int arraysize; //元素個(gè)數(shù) 
    int *array; //用于動(dòng)態(tài)開(kāi)辟數(shù)組的指針變量 
 
    cin>>arraysize; 
    array=(int*)malloc(arraysize * sizeof(int));//利用malloc在堆內(nèi)存中開(kāi)辟內(nèi)存空間,它的大小是元素的個(gè)數(shù)乘以該數(shù)據(jù)類(lèi)型的長(zhǎng)度 
 
    for(int i=0;i<arraysize;i++)  
    { 
        array[i]=i; 
    } 
 
    for(int i=0;i<arraysize;i++) 
    { 
        cout<<array[i]<<","; 
    } 
    cout<<endl; 
    free(array);//利用free釋放動(dòng)態(tài)開(kāi)辟的堆內(nèi)存空間 
    cin.get(); 
    cin.get(); 
}

  這里要特別注意個(gè)地方就是:

array=(int*)malloc(arraysize * sizeof(int));

  malloc()的函數(shù)原形本身是void* malloc(size_t size),由于動(dòng)態(tài)分配的空間計(jì)算機(jī)并不知道是用來(lái)做什么的所以是無(wú)類(lèi)型的,但你要把它用在動(dòng)態(tài)的整形數(shù)組上的時(shí)候就要顯式的轉(zhuǎn)換成int*了。

  下面我們?cè)俳榻Bc++所獨(dú)有的開(kāi)辟和釋放堆內(nèi)存空間的方法,new修飾符和delete修飾符。

  new和delete修飾符的操作并不需要頭文件的支持,這是c++所獨(dú)有的,new操作要比malloc更為簡(jiǎn)單,直接說(shuō)明開(kāi)辟的類(lèi)型的數(shù)目就可以了,delete使用的時(shí)候如果是數(shù)組那么必須使用delete[]。

#include <iostream
 
using namespace std; 
main() 

    int arraysize; //元素個(gè)數(shù) 
    int *array; 
 
    cin>>arraysize; 
     
    array=new int[arraysize];//開(kāi)辟堆內(nèi)存 
 
    for(int i=0;i<arraysize;i++)  
    { 
        array[i]=i; 
    } 
 
    for(int i=0;i<arraysize;i++) 
    { 
        cout<<array[i]<<","; 
    } 
    cout<<endl; 
    delete[] array;//釋放堆內(nèi)存 
    cin.get(); 
    cin.get(); 
}  

302 Found

302 Found


Powered by Tengine
tengine