• <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>

            劉加加在成長(zhǎng)(C++語(yǔ)言學(xué)習(xí)中)

            學(xué)習(xí)、工作、生活,這是三個(gè)問(wèn)題。

              C++博客 :: 首頁(yè) :: 新隨筆 :: 聯(lián)系 :: 聚合  :: 管理 ::
              38 隨筆 :: 0 文章 :: 24 評(píng)論 :: 0 Trackbacks
                  動(dòng)態(tài)數(shù)組,顧名思義,就是可以動(dòng)態(tài)分配長(zhǎng)度的數(shù)組。在c語(yǔ)言中,數(shù)組的長(zhǎng)度是固定的,而這種限制顯然是很不靈活的。在c++中,數(shù)組有時(shí)候不用在編譯時(shí)就知道長(zhǎng)度,直到運(yùn)行時(shí)才知道。與普通的數(shù)組變量不同,動(dòng)態(tài)分配的數(shù)組將一直存在,直到程序顯式的釋放它為止。

            定義:

                  int *p=new int[20];

                  p就是一個(gè)動(dòng)態(tài)數(shù)組,這時(shí)我們發(fā)現(xiàn),其實(shí)所謂的動(dòng)態(tài)數(shù)組就是一個(gè)指針,使用new為p分配長(zhǎng)度。我們可以通過(guò)這種方式初始化: int *p=new int[20]();

                  同樣上面的語(yǔ)句等同于:
                  int n=20; 
                  int *p=new int[n];
                  因?yàn)閚是一個(gè)變量,所以數(shù)組的長(zhǎng)度是動(dòng)態(tài)的。

            操作實(shí)例:

                  int n=20; 
                  int *p=new int[n];

                  p可以使用數(shù)組下標(biāo)為其賦值:
                  for(int i=0;i<n;i++)
                  {
                        p[i]=i+3;
                  }
                 上面這種方式?jīng)]有問(wèn)題,但我想既然p是一個(gè)指針,那么使用指針操作一樣也可以吧?

                 for(int i=0;i<n;i++,p++)
                {
                       *p=i;
                 }
             
                  這樣就可以了,將他們輸出:(這時(shí)指針p又指向了最后)
                  
                  p--;
                  for(int *p2=p-10;p2!=p;p--)
                  {
                       cout<<*p<<endl;
                  }

            動(dòng)態(tài)空間釋放:

                  最后重要的是別忘了將動(dòng)態(tài)創(chuàng)造的空間釋放掉,語(yǔ)句是:delete [] p;   ‘[ ]’表明該指針是指向的自由存儲(chǔ)區(qū)的數(shù)組,而非單個(gè)對(duì)象。如果遺漏了空方括號(hào),編譯器將無(wú)法發(fā)現(xiàn)這個(gè)錯(cuò)誤,將導(dǎo)致程序在運(yùn)行時(shí)出錯(cuò)。

            完成了!以下是完整代碼:

            #include<iostream>
            using namespace std;
            int main(void)
            {
                
            int n=20;
                
            int *p=new int[n];
                
            for(int i=0;i<n;i++,p++)
                {
                    cout
            <<p<<endl;
                    
            *p=i;
                }
                p
            --;
                
            for(int *p2=p-n;p2!=p;p--)
                {
                    cout
            <<*p<<endl;
                }
                
                delete [] p;
                
                getchar();
            }

            posted on 2008-07-12 23:26 劉加加 閱讀(12421) 評(píng)論(2)  編輯 收藏 引用

            評(píng)論

            # re: 創(chuàng)建和使用動(dòng)態(tài)數(shù)組[未登錄](méi) 2013-03-15 11:03 坐行客
            完整代碼有錯(cuò),釋放了申請(qǐng)內(nèi)存之外的內(nèi)存。在delete前加一句p++即可。  回復(fù)  更多評(píng)論
              

            # re: 創(chuàng)建和使用動(dòng)態(tài)數(shù)組 2013-06-19 11:10 xx
            樓上所言即是  回復(fù)  更多評(píng)論
              


            只有注冊(cè)用戶(hù)登錄后才能發(fā)表評(píng)論。
            網(wǎng)站導(dǎo)航: 博客園   IT新聞   BlogJava   博問(wèn)   Chat2DB   管理


            久久人妻少妇嫩草AV无码蜜桃| 伊人久久大香线蕉精品不卡| 久久亚洲国产精品成人AV秋霞 | 久久99国产乱子伦精品免费| 性做久久久久久久久浪潮| 久久夜色精品国产噜噜亚洲a| 中文字幕无码久久精品青草| 人妻少妇久久中文字幕一区二区| 精品久久久久久亚洲| 久久久精品无码专区不卡| 国内高清久久久久久| 久久精品成人国产午夜| 蜜臀久久99精品久久久久久| 色欲综合久久中文字幕网| 久久久久久久久久免免费精品| 欧美日韩精品久久久久| 久久精品国产精品青草| 国产毛片欧美毛片久久久| 伊人久久大香线蕉影院95| 一本色道久久综合亚洲精品| 91超碰碰碰碰久久久久久综合| 久久精品中文无码资源站| 久久综合鬼色88久久精品综合自在自线噜噜| 国产成人精品综合久久久久 | 99久久99这里只有免费费精品| 久久香蕉国产线看观看99| 亚洲AV无码久久精品成人| 久久97久久97精品免视看秋霞| 99热成人精品免费久久| 久久久综合九色合综国产| 日韩精品久久无码人妻中文字幕| 久久91精品综合国产首页| 国产精品无码久久久久久| 一本一本久久A久久综合精品| 亚洲午夜无码久久久久小说| 久久夜色精品国产亚洲av| 久久精品二区| 亚洲国产成人精品女人久久久| 色婷婷久久综合中文久久一本| 国产成人精品久久亚洲高清不卡| 麻豆精品久久精品色综合|