• <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)  編輯 收藏 引用

            久久se精品一区二区影院| 无码久久精品国产亚洲Av影片| avtt天堂网久久精品| AV狠狠色丁香婷婷综合久久| 国产一区二区三区久久| 久久精品国产福利国产琪琪| 久久99精品久久久久久野外| 亚洲欧美日韩久久精品第一区| 狠狠色丁香久久婷婷综合五月 | 久久久久国产一级毛片高清板| 色诱久久av| 久久精品嫩草影院| 无码任你躁久久久久久| 久久97精品久久久久久久不卡| 欧美日韩精品久久久免费观看| 久久丫精品国产亚洲av| 久久影院久久香蕉国产线看观看| 久久久久久精品免费免费自慰| 久久91精品国产91久久户| 伊人久久国产免费观看视频| 丁香狠狠色婷婷久久综合| 伊人久久无码中文字幕| 久久乐国产精品亚洲综合| 国产精品久久久福利| 一本色道久久99一综合| 久久99精品久久久久久不卡| 成人国内精品久久久久影院| 蜜臀久久99精品久久久久久小说| 午夜视频久久久久一区| 狠狠人妻久久久久久综合蜜桃| 久久精品中文字幕无码绿巨人| 免费精品久久天干天干| 久久综合视频网| 日韩人妻无码一区二区三区久久99| 久久精品国产精品青草| 成人久久精品一区二区三区| 香蕉久久夜色精品升级完成| 久久久久99这里有精品10| 日韩电影久久久被窝网| 欧美无乱码久久久免费午夜一区二区三区中文字幕 | 国产精品成人无码久久久久久|