• <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>
            C++分析研究  
            C++
            日歷
            <2013年2月>
            272829303112
            3456789
            10111213141516
            17181920212223
            242526272812
            3456789
            統(tǒng)計
            • 隨筆 - 92
            • 文章 - 4
            • 評論 - 4
            • 引用 - 0

            導航

            常用鏈接

            留言簿

            隨筆檔案

            文章檔案

            搜索

            •  

            最新評論

            閱讀排行榜

            評論排行榜

             

              對于二維數(shù)組和二維指針的內(nèi)存的分配
              這里首選說一下一維指針和一維數(shù)組的內(nèi)存分配情況。
              一維:
              數(shù)組:形如int a[5];這里定義了一個一維數(shù)組a,并且數(shù)組的元素個數(shù)是5,這里的a是這五個元素的整體表示,也就是通過a我們能找到這五個元素。注意:a是代表數(shù)組第一個元素的首地址。&a是代表數(shù)組的地址,雖然它們的值相同。
              指針: int *p = NULL;這里p是一個指針,它指向的是計算
              機內(nèi)一塊存儲int類型的內(nèi)存。P = a;就是讓p等于剛才申請的數(shù)組的第一個元素的地址。所以通過p我們也能找到那5個元素所以P[i]跟a[i]的作用一樣。
              注意:
              1:int *p = NULL; p的大小在32位機器是4,即使p=a;之后p的sizeof(p)仍然等于4.
              2:在聲明之后,數(shù)組必須分配內(nèi)存進行初始化。而指針一般是動態(tài)分配其指向的內(nèi)存。
              3:不要混淆指針和數(shù)組,指針就是指針,數(shù)組就是數(shù)組,只是數(shù)組在一定條件下可以轉(zhuǎn)換成指針。不要將指針和數(shù)組混淆。(例如:指針有++,--操作,數(shù)組則不可以)。
              一維指針的動態(tài)內(nèi)存分配:
              int *p = NULL;
              p = new int[N];
              千萬別忘了delete
              delete [] p;
              p = NULL;
              二維數(shù)組的內(nèi)存分配
              int a[2][3]; 這里分配了一個2X3=6個int大小的數(shù)組。二維數(shù)組的第二個維度3不能省略。
              二維數(shù)組的內(nèi)存在計算機內(nèi)也是連續(xù)的一片地址,只不過每3個元素構(gòu)成一個一維數(shù)組a[i],這里的a[i]代表維度為3的數(shù)組的第一個元素的地址。所以a[i][j]的訪問跟a[i]的訪問也就清楚了。這里的a[i]其實是一個一維數(shù)組的第一個元素的地址。
              對于二維數(shù)組做實參,我們通常用一維指針處理,例如:
              1 #include
              2 void test(int *p)
              3 {
              4 for (int i = 0;i<3;++i)
              5 {
              6 for(int j = 0;j<3;++j)
              7 {
              8 std::cout《*(p+3*i+j); //一維處理
              9 }
              10 }
              11 }
              12 int main(void)
              13 {
              14 int a[3][3]={1,2,3,4,5,6,7,0,0};
              15 test((int*)a); //將二維數(shù)組當做一維處理
              16 system("pause");
              17 return 0;
              18 }
              這些想必書上講的都非常清楚。
              二維數(shù)組的C++動態(tài)內(nèi)存分配。
              二維指針的動態(tài)數(shù)組分配:二維指針類似指針數(shù)組的分配
              int **p;
              1 #include
              2 int main(void)
              3 {
              4 int **p = NULL; //這里申請一個3x4的二維數(shù)組
              5 p = new int *[3]; //分配一維指針,分配三個int* 類型的一維指針。
              6 for (int i = 0;i < 3; ++i)
              7 {
              8 p[i] = new int[4];
              9 }
              10 for (int i = 0; i < 3; ++i)
              11 {
              12 for(int j = 0; j < 4 ; ++j)
              13 {
              14 p[i][j] = i*j;
              15 std::cout<
              26 return 0;
              27 }
              指針數(shù)組的動態(tài)內(nèi)存分配
              指針數(shù)組的動態(tài)內(nèi)存分配只需要對指針數(shù)組的數(shù)組元素指針分別分配內(nèi)存即可,比二維指針的分配少了一個環(huán)節(jié)。
              1 #include托福答案
              2 int main(void)
              3 {
              4 int *a[3]; //申請含有三個int* 類型的指針數(shù)組
              5 //跟二維指針不同的是,這里數(shù)組a不用手動申請內(nèi)存
              6 for (int i = 0;i < 3;++i) //申請一個3x4的空間
              7 {
              8 a[i] = new int[4];
              9 }
              10 for (int i = 0; i<3 ;++i)
              11 {
              12 for (int j = 0; j<4; ++j)
              13 {
              14 a[i][j] = i*j;
              15 std::cout<
              25 return 0;
              26 }
              數(shù)組指針的動態(tài)內(nèi)存分配
              數(shù)組指針就是指向數(shù)組的指針,說白了就是指向一個數(shù)組整體,因此分配的時候直接申請一片內(nèi)存地址即可。跟二維數(shù)組的靜態(tài)分配類似。
              1 // Karllen
              2 int main(void)
              3 {
              4 int (*a)[4]; //這里的4是第二維的維度,a的增量的基數(shù)為4個int
              5 a = new int[3][4];
              6 delete []a;
              7 a = NULL;
              8 return 0;
              9 }

            posted on 2014-05-28 20:29 HAOSOLA 閱讀(441) 評論(0)  編輯 收藏 引用
             
            Copyright © HAOSOLA Powered by: 博客園 模板提供:滬江博客
            PK10開獎 PK10開獎
            中文国产成人精品久久不卡| 精品无码人妻久久久久久| 少妇无套内谢久久久久| 久久亚洲AV无码精品色午夜| 久久99精品久久久久久久久久 | 精品欧美一区二区三区久久久| 久久精品无码专区免费| 久久天堂AV综合合色蜜桃网| 国内精品久久九九国产精品| 人妻无码精品久久亚瑟影视| 91精品国产综合久久久久久| 亚洲伊人久久成综合人影院 | 亚洲午夜久久久| 91精品国产9l久久久久| 一本久久免费视频| 国产—久久香蕉国产线看观看| 久久综合综合久久综合| 国产精品青草久久久久福利99| 人妻久久久一区二区三区| 97精品伊人久久大香线蕉| 一本久久a久久精品综合夜夜| 久久精品午夜一区二区福利| 亚洲v国产v天堂a无码久久| Xx性欧美肥妇精品久久久久久| 亚洲国产精品无码久久| 久久久久久久91精品免费观看| 久久久久亚洲av毛片大| 精品久久久无码中文字幕天天| 久久婷婷五月综合色高清| 亚洲日本va中文字幕久久| 99久久国产亚洲综合精品| 久久久久国产精品人妻| 久久久无码精品亚洲日韩京东传媒| 性高湖久久久久久久久AAAAA| 女人香蕉久久**毛片精品| 久久99国产精品99久久| 久久精品国产福利国产秒| 99久久国产热无码精品免费| 久久青草国产精品一区| 久久国产精品久久国产精品| 国产成人精品久久综合|