C++中關於[]靜態數組和new分配的動態數組的區別分析

本文以實例分析了C++語言中關於[]靜態數組和new分配的動態數組的區別,可以幫助大家加深對C++語言數組的理解。具體區別如下:

一、對靜態數組名進行sizeof運算時,結果是整個數組佔用空間的大小;
因此可以用sizeof(數組名)/sizeof(*數組名)來獲取數組的長度。
int a[5]; 則sizeof(a)=20,sizeof(*a)=4.因爲整個數組共佔20字節,首個元素(int型)佔4字節。
int *a=new int[4];則sizeof(a)=sizeof(*a)=4,因爲地址位數爲4字節,int型也佔4字節。
二、靜態數組作爲函數參數時,在函數內對數組名進行sizeof運算,結果爲4,因爲此時數組名代表的指針即一個地址,佔用4個字節的內存(因爲在傳遞數組名的參數時,編譯器對數組的長度不做檢查,具體可參考前面一篇c++對數組的引用實例分析)。對動態數組的函數名,無論何時進行sizeof運算,得到的結果都是4.
三、new還需要你delete,是在堆分配空間,效率較低;而[]直接在棧上分配,會自動釋放,效率高,但是棧空間有限。
四、通過函數返回一個數組的問題

函數聲明的靜態數組不可能通過函數返回,因爲生存期的問題,函數調用完其內部變量佔用的內存就被釋放了。如果想通過函數返回一個數組,可以在函數中用new動態創建該數組,然後返回其首地址。
其原因可以這樣理解,因爲[]靜態數組是在棧中申請的,而函數中的局部變量也是在棧中的,而new動態數組是在堆中的分配的,所以函數返回後,棧中的東西被自動釋放,而堆中的東西如果沒有delete不會自動釋放。
例子如下:

int *test(int *b) //b可以是靜態數組的數組名,也可以是動態數組的首地址
{
  for(int i=0;i<5;i++) //輸出傳入的數組各元素
   cout<<*(b+i)<<" ";
  cout<<endl;
  int *c=new int[5]; //動態創建一個數組
  //如果將綠色部分換爲int c[5];則主函數中調用test無法得到c數組
  for(i=0;i<5;i++)  //新數組的各項值等於傳入的數組各項值加5
   *(c+i)=*(b+i)+5;
  return c;     //返回新創建的動態數組的首地址
}
int main()
{
 int *b=new int[5]; //創建動態數組b
 for(int i=0;i<5;i++)//賦值
  *(b+i)=i; 
 //綠色部分也可以換爲int b[5]={0,1,2,3,4};即也可以是靜態數組
 int *c=test(b);   //將b作爲參數,調用test函數,返回值賦給c
 for(i=0;i<5;i++)  //輸出test返回的數組的各項
   cout<<*(c+i)<<" ";
 cout<<endl;
 return 0;
}

相信看過本文實例分析之後可以進一步加深讀者對C++數組的認識。
原文鏈接:http://www.jb51.net/article/53870.htm

發佈了66 篇原創文章 · 獲贊 85 · 訪問量 23萬+
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章