• <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>
            隨筆 - 51, 文章 - 1, 評論 - 41, 引用 - 0
            數據加載中……

            CPPEXP —— 構造析構函數調用順序

            ## 說明

            構造函數的調用順序是先父類再子類。析構函數的順序相反——先子類再父類。有繼承關系的類的析構函數需要聲明為virtual,但并非必須。聲明virtual表明函數不能再編譯期間確定,只有在運行時才能確定。這樣的場景是刪除基類指針,但其指向是派生類。此時編譯器看到的只有基類信息,如果沒有聲明virtual,就沒有虛函數表或者虛函數表沒有析構函數項,只能調用基類的析構函數。如果不聲明virtual,將子類指針賦值給父類指針是有風險的操作。



            ## 實驗代碼


            ```C

            /**

             * @file constructor_destructor_sequence.cpp

             * @brief 測試構造析構函數的調用次序

             * @copyright public domain

             */


            #include <iostream>


            class Base {

            public:

                Base() { std::cout << "Base()" << std::endl; }

                ~Base() { std::cout << "~Base()" << std::endl; }

            };


            class VBase {

            public:

                VBase() { std::cout << "VBase()" << std::endl; }

                virtual ~VBase() { std::cout << "~VBase()" << std::endl; }

            };


            class Derived : public Base {

            public:

                Derived() { std::cout << "Derived()" << std::endl; }

                ~Derived() { std::cout << "~Derived()" << std::endl; }

            };


            class VDerived: public VBase {

            public:

                Derived() { std::cout << "VDerived()" << std::endl; }

                ~VDerived() { std::cout << "~VDerived()" << std::endl; }

            };


            void test_0() {

                std::cout <<"子類不聲明virtual,按基類指針刪除派生類" << std::endl;

                VBase* p = new VDerived;

                delete p;

            }


            void test_1() {

                std::cout <<"不聲明virtual,按派生類指針刪除派生類" << std::endl;

                Derived* p = new Derived;

                delete p;

            }


            void test_2() {

                std::cout <<"不聲明virtual,按基類指針刪除派生類" << std::endl;

                Base* p = new Derived;

                delete p;

            }


            void test_3() {

                std::cout <<"不聲明virtual,按void*刪除派生類" << std::endl;

                void* p = new Derived;

                delete p;

            }


            int main() {

                test_0();

                test_1();

                test_2();

                test_3();


                return 0;

            }

            ```


            ## 運行及結果


                > g++ constructor_destructor_sequence.cpp

                constructor_destructor_sequence.cpp: In function 'void test_3()':

                constructor_destructor_sequence.cpp:54:9: warning: deleting 'void*' is undefined [enabled by default]


                > a.exe

                子類不聲明virtual,按基類指針刪除派生類

                VBase()

                VDerived()

                ~VDerived()

                ~VBase()

                不聲明virtual,按派生類指針刪除派生類

                Base()

                Derived()

                ~Derived()

                ~Base()

                不聲明virtual,按基類指針刪除派生類

                Base()

                Derived()

                ~Base()

                不聲明virtual,按void*刪除派生類

                Base()

                Derived()







            posted on 2016-04-23 18:26 lemene 閱讀(345) 評論(0)  編輯 收藏 引用

            久久精品国产国产精品四凭| 久久精品国产亚洲精品| 精品多毛少妇人妻AV免费久久| 午夜精品久久久久久| 日本强好片久久久久久AAA| 久久91精品国产91久久麻豆| 久久久久综合中文字幕| 久久精品亚洲日本波多野结衣 | 蜜臀av性久久久久蜜臀aⅴ | 亚洲欧美成人综合久久久| 亚洲日韩中文无码久久| 国产成人综合久久精品尤物| 久久婷婷人人澡人人爽人人爱| 久久免费精品一区二区| 久久久黄色大片| 久久亚洲中文字幕精品一区| 国产色综合久久无码有码| 国产精品久久久天天影视香蕉 | 伊人久久五月天| 久久精品视频网| 少妇久久久久久久久久| 久久夜色精品国产| 精品久久久久中文字| www久久久天天com| 日日噜噜夜夜狠狠久久丁香五月| 少妇久久久久久被弄到高潮| 国产精品激情综合久久| 亚洲综合婷婷久久| 日本福利片国产午夜久久| 精品国产一区二区三区久久| 人妻无码中文久久久久专区| 久久精品国产亚洲av麻豆图片| 一本色道久久综合| 一本一道久久a久久精品综合 | 亚洲va久久久噜噜噜久久狠狠| 久久影院亚洲一区| 欧美日韩精品久久久久| 欧美性大战久久久久久| 久久这里的只有是精品23| 久久精品中文无码资源站| 亚洲va久久久噜噜噜久久天堂|