• <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>
            posts - 12,  comments - 21,  trackbacks - 0

            #include <iostream.h>

            class B

            {

                   int x,y;

            public:

                   B() {x = y = 0; cout << “Constructor1” << endl;}

                   B(int i) {x = i; y = 0; cout << “Constructor2” << endl;}

                   B(int i ,int j) {x = i; y = j; cout << “Constructor3” << endl;}

                   ~B() {cout << “Destructor” << endl;}

                   void print() {cout << “x=” << x << “,y=” << y << endl;}

            };

            void main()

            {

                   B *ptr;

                   ptr = new B[3];

                   ptr[0] = B();

                   ptr[1] = B(5);

                   ptr[2] = B(2,3);

                   for (int i=0;i<3;i++)

                          ptr[i].print();

                   delete[] ptr;

            }


            運(yùn)行結(jié)果為什么是:

            Constructor1

            Constructor1

            Constructor1

            Constructor1

            Destructor

            Constructor2

            Destructor

            Constructor3

            Destructor

            x=0,y=0

            x=5,y=0

            x=2,y=3

            Destructor

            Destructor

            Destructor

            它是如何調(diào)用構(gòu)造函數(shù)和析構(gòu)函數(shù)的???

            思考以下我想可能是這樣運(yùn)行的:
            B *ptr ;                  //建立一個(gè)指針對(duì)象 先調(diào)用一次構(gòu)造函數(shù)B();
            ptr=new  B[3];        //用new獲取動(dòng)態(tài)內(nèi)存,并且建立了3個(gè)對(duì)象
            ptr[0]=B();             //調(diào)用構(gòu)造函數(shù)B()
            ptr[1]=B(5);           //調(diào)用重載構(gòu)造函數(shù)B(int i)
            ptr[2]=B(2,3)          //調(diào)用重載構(gòu)造函數(shù)B(int i,intj)
            然后調(diào)用一次析構(gòu)函數(shù);
            最后 delete[] ptr;    逆序調(diào)用三次析構(gòu)函數(shù).


            posted on 2011-06-01 13:38 DoubleW 閱讀(3267) 評(píng)論(2)  編輯 收藏 引用

            FeedBack:
            # re: 構(gòu)造函數(shù)和析構(gòu)函數(shù)調(diào)用問題
            2011-06-02 08:46 | lwch
            B* ptr并不會(huì)調(diào)用構(gòu)造函數(shù),只不過在棧上聲明了一個(gè)指針對(duì)象。
            new B[3]調(diào)用了3次構(gòu)造函數(shù),生成了3個(gè)對(duì)象。
            B()調(diào)用了一次構(gòu)造函數(shù),因?yàn)樗窃跅I仙傻模虼诉@行代碼執(zhí)行完后會(huì)調(diào)用析構(gòu)函數(shù)析構(gòu)這個(gè)對(duì)象。
            下面兩句同上。
            最后delete[] ptr因?yàn)橛卸焉?個(gè)對(duì)象,因此會(huì)被析構(gòu)3次。

            要記住棧上創(chuàng)建的對(duì)象會(huì)被自動(dòng)析構(gòu),堆上創(chuàng)建的對(duì)象必須手動(dòng)析構(gòu)。  回復(fù)  更多評(píng)論
              
            # re: 構(gòu)造函數(shù)和析構(gòu)函數(shù)調(diào)用問題
            2011-06-02 11:45 | DoubleW
            看懂了,多下閣下悉心教導(dǎo)。還望以后多家照顧..呵呵  回復(fù)  更多評(píng)論
              

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


            <2025年5月>
            27282930123
            45678910
            11121314151617
            18192021222324
            25262728293031
            1234567

            常用鏈接

            留言簿(3)

            隨筆檔案(12)

            文章檔案(2)

            最新隨筆

            搜索

            •  

            積分與排名

            • 積分 - 28951
            • 排名 - 662

            最新隨筆

            最新評(píng)論

            閱讀排行榜

            評(píng)論排行榜

            999久久久无码国产精品| 偷偷做久久久久网站| 国内精品九九久久久精品| 久久国产精品成人片免费| 99精品国产在热久久无毒不卡 | 91亚洲国产成人久久精品| 久久久久久国产精品免费免费| 一本色综合久久| 久久天堂AV综合合色蜜桃网| 国产成人精品久久| 国产A三级久久精品| 久久播电影网| 国产三级久久久精品麻豆三级| 精品国产热久久久福利| 色偷偷偷久久伊人大杳蕉| 久久精品一区二区影院| 久久精品国产亚洲AV无码麻豆| 久久亚洲高清综合| 狠狠人妻久久久久久综合| 久久久久亚洲av无码专区喷水| 久久成人精品| 夜夜亚洲天天久久| 久久久久一区二区三区| 久久亚洲精品人成综合网| 久久毛片一区二区| 亚洲欧洲久久av| 国内精品久久久久久久影视麻豆| 精品熟女少妇a∨免费久久| 国色天香久久久久久久小说| 久久久中文字幕日本| 国产精品伊人久久伊人电影| 国产日产久久高清欧美一区| 久久青青草原精品国产| 午夜精品久久久久久99热| 亚洲国产另类久久久精品| 亚洲国产综合久久天堂| 午夜视频久久久久一区| 亚洲国产精品成人久久蜜臀| 久久久99精品成人片中文字幕| 精品99久久aaa一级毛片| 久久狠狠一本精品综合网|