亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

C++中關(guān)于[]靜態(tài)數(shù)組和new分配的動態(tài)數(shù)組的區(qū)別分析

 更新時間:2014年08月18日 10:18:38   投稿:shichen2014  
這篇文章主要介紹了C++中關(guān)于[]靜態(tài)數(shù)組和new分配的動態(tài)數(shù)組的區(qū)別分析,很重要的概念,需要的朋友可以參考下

本文以實例分析了C++語言中關(guān)于[]靜態(tài)數(shù)組和new分配的動態(tài)數(shù)組的區(qū)別,可以幫助大家加深對C++語言數(shù)組的理解。具體區(qū)別如下:

一、對靜態(tài)數(shù)組名進(jìn)行sizeof運算時,結(jié)果是整個數(shù)組占用空間的大小;
因此可以用sizeof(數(shù)組名)/sizeof(*數(shù)組名)來獲取數(shù)組的長度。
int a[5]; 則sizeof(a)=20,sizeof(*a)=4.因為整個數(shù)組共占20字節(jié),首個元素(int型)占4字節(jié)。
int *a=new int[4];則sizeof(a)=sizeof(*a)=4,因為地址位數(shù)為4字節(jié),int型也占4字節(jié)。

二、靜態(tài)數(shù)組作為函數(shù)參數(shù)時,在函數(shù)內(nèi)對數(shù)組名進(jìn)行sizeof運算,結(jié)果為4,因為此時數(shù)組名代表的指針即一個地址,占用4個字節(jié)的內(nèi)存(因為在傳遞數(shù)組名的參數(shù)時,編譯器對數(shù)組的長度不做檢查,具體可參考前面一篇c++對數(shù)組的引用實例分析)。對動態(tài)數(shù)組的函數(shù)名,無論何時進(jìn)行sizeof運算,得到的結(jié)果都是4.

三、new還需要你delete,是在堆分配空間,效率較低;而[]直接在棧上分配,會自動釋放,效率高,但是??臻g有限

四、通過函數(shù)返回一個數(shù)組的問題

函數(shù)聲明的靜態(tài)數(shù)組不可能通過函數(shù)返回,因為生存期的問題,函數(shù)調(diào)用完其內(nèi)部變量占用的內(nèi)存就被釋放了。如果想通過函數(shù)返回一個數(shù)組,可以在函數(shù)中用new動態(tài)創(chuàng)建該數(shù)組,然后返回其首地址。
其原因可以這樣理解,因為[]靜態(tài)數(shù)組是在棧中申請的,而函數(shù)中的局部變量也是在棧中的,而new動態(tài)數(shù)組是在堆中的分配的,所以函數(shù)返回后,棧中的東西被自動釋放,而堆中的東西如果沒有delete不會自動釋放

例子如下:

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

相信看過本文實例分析之后可以進(jìn)一步加深讀者對C++數(shù)組的認(rèn)識。

相關(guān)文章

  • 詳解在VScode中添加代碼塊(含C++指令生成代碼)

    詳解在VScode中添加代碼塊(含C++指令生成代碼)

    這篇文章主要介紹了詳解在VScode中添加代碼塊(含C++指令生成代碼),文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2021-04-04
  • 利用OpenCV實現(xiàn)綠幕視頻背景替換

    利用OpenCV實現(xiàn)綠幕視頻背景替換

    這篇文章主要介紹了如何利用OpenCV實現(xiàn)綠幕視頻背景替換功能,文中的示例代碼講解詳細(xì),對我們學(xué)習(xí)OpenCV有一定的幫助,感興趣的可以學(xué)習(xí)一下
    2022-01-01
  • 全面解析C++中的析構(gòu)函數(shù)

    全面解析C++中的析構(gòu)函數(shù)

    這篇文章主要介紹了C++中的析構(gòu)函數(shù),為C++入門學(xué)習(xí)中的基礎(chǔ)知識,需要的朋友可以參考下
    2016-01-01
  • C語言中的內(nèi)存管理詳情

    C語言中的內(nèi)存管理詳情

    這篇文章主要介紹了C語言中的內(nèi)存管理詳情,手工申請內(nèi)存使用malloc展開全文內(nèi)容,具有一定的參考價值,需要的小伙伴可以參考一下
    2022-05-05
  • C++ Effective詳解

    C++ Effective詳解

    下面小編就為大家?guī)硪黄狢++ Effective的文章。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2021-08-08
  • STL容器之list源碼詳細(xì)解讀

    STL容器之list源碼詳細(xì)解讀

    這篇文章主要介紹了STL容器之list源碼詳細(xì)解讀,相對于vector的連續(xù)線性空間,list就顯得更加復(fù)雜,它每插入或者刪除一個元素,就配置或釋放一個元素空間,需要的朋友可以參考下
    2024-01-01
  • C++并查集算法簡單詳解

    C++并查集算法簡單詳解

    大家好,本篇文章主要講的是C++并查集算法簡單詳解,感興趣的同學(xué)趕快來看一看吧,對你有幫助的話記得收藏一下
    2022-02-02
  • Qt圖形圖像開發(fā)之曲線圖表庫QChart編譯安裝詳細(xì)方法與使用實例

    Qt圖形圖像開發(fā)之曲線圖表庫QChart編譯安裝詳細(xì)方法與使用實例

    這篇文章主要介紹了Qt圖形圖像開發(fā)之曲線圖表庫QChart編譯安裝詳細(xì)方法與使用實例,需要的朋友可以參考下
    2020-03-03
  • C++發(fā)郵件簡單實例詳解

    C++發(fā)郵件簡單實例詳解

    這篇文章主要為大家詳細(xì)介紹了C++發(fā)郵件的簡單實例,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2018-05-05
  • C++常用函數(shù)之XML JSON格式轉(zhuǎn)換問題

    C++常用函數(shù)之XML JSON格式轉(zhuǎn)換問題

    XML在Json出現(xiàn)前應(yīng)用很廣泛,靈活性好,應(yīng)用語言也沒有限制,發(fā)展了這么長時間后xml標(biāo)準(zhǔn)已經(jīng)很臃腫。這篇文章主要介紹了C++常用函數(shù)之XML JSON格式轉(zhuǎn)換問題,需要的朋友可以參考下
    2020-02-02

最新評論