• <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>
            隨筆 - 2  文章 - 17  trackbacks - 0
            <2025年5月>
            27282930123
            45678910
            11121314151617
            18192021222324
            25262728293031
            1234567

            常用鏈接

            留言簿(1)

            隨筆檔案(2)

            搜索

            •  

            最新評論

            閱讀排行榜

            評論排行榜

            一會兒再把分析轉(zhuǎn)過來。



            #include
            <iostream>
            using namespace std;
            class A
            {
            public:
                A(
            int n):val(n){}
            protected:
               
            int val;
            };
            class B:public A
            {
            public:
                B(
            int n):A(n)
                {
                    pB
            =(n>0? new B(n-1):0);
                }
               
            ~B(){delete pB;}
               
            void Display()
                {
                    cout
            << val << endl;
                   
            if(pB!=0)pB->Display();
                }
            private:
                B
            *pB;
            };
            int main()
            {
                B b(
            4);
                b.Display();
               
            return 0;
            }



            ==================================================================




            程序的運行結(jié)果是:
                            4
                            3
                            2
                            1
                            0



            ===================================================================

            tangshuiling 給出的解釋:

            B(int n):A(n)
            {
            pB=(n>0? new B(n-1):0);
            }

            B b(4); /**用 4 初始化 A 類成員 val, val=4*/
            /**此時 n=4 滿足大于 0 的條件,調(diào)用 new B(3),同時棧要維護現(xiàn)場,
            存儲 val=4,pb=new B(3) 產(chǎn)生的對象地址設為 pb1 以及函數(shù)的下個語句
            地址,此時是‘}’就相當于return。
            */

            依次類推棧中保存了 (val=4,pb1) (val=3,pb2) (val=2,pb3) (val=1,pb4) 最后 val=0, pb=0
            ,遇到‘}’符號本應該 return 的,但由于此時棧不空,因此還必須做出棧的操作,因此,最后出棧是:val=4, pb1。

            b.Display();
            調(diào)用此句,顯然此時 val=4,pb=pb1 pb1->display(); 此時 val 應該是
            等于3,pb1=new B(3); 依次類推:

            pb2->display(); val=2
            pb3->display(); val=1
            pb4->display(); val=0

            此時 pb=0,不滿足調(diào)用條件直接 return 了

            from:http://topic.csdn.net/u/20090109/00/67841ac5-3197-4842-b0e9-ce3c6aa962d9.html
            posted on 2009-01-12 09:34 末檐兒@了修 閱讀(1479) 評論(16)  編輯 收藏 引用

            FeedBack:
            # re: 一道有意思的題目,大家看看輸出:) [未登錄] 2009-01-12 12:33 dd
            在創(chuàng)建對象b后,b的成員變量pB是指向的B(3)這個對象的地址,那么調(diào)用Display,不就是顯示4和3嗎?  回復  更多評論
              
            # re: 一道有意思的題目,大家看看輸出:) [未登錄] 2009-01-12 12:40 dd
            Display也是一個遞歸函數(shù)嘛,b這個對象指向的是B(4)這個對象,這個對象的成員pb指象B(3)這個對象,在調(diào)用Display的時候,又會調(diào)用B(3)這個對象的Display。依此類推,直到pb為NULL。  回復  更多評論
              
            # re: 一道有意思的題目,大家看看輸出:)  2009-01-12 13:38 yu
            這里的解釋是否有不合理的地方?

            "依次類推棧中保存了 (val=4,pb1) (val=3,pb2) (val=2,pb3) (val=1,pb4) 最后 val=0, pb=0
            ,遇到‘}’符號本應該 return 的,但由于此時棧不空,因此還必須做出棧的操作,因此,最后出棧是:val=4, pb1。"


            這里為什么棧不為空就必須要做出出棧的操作?最后出棧的不是應該最后輸出才對?  回復  更多評論
              
            # re: 一道有意思的題目,大家看看輸出:)  2009-01-12 14:02 了修
            個人認為:這里的出棧,是相對于return來說的,pb 和 val 逐次回歸。
            關鍵看自己怎么理解了

            @yu
              回復  更多評論
              
            # re: 一道有意思的題目,大家看看輸出:)  2009-01-12 15:23 ss
            跟現(xiàn)場保護什么事?
            這不就像建了個鏈表,一順打印出節(jié)點值嗎。  回復  更多評論
              
            # re: 一道有意思的題目,大家看看輸出:)  2009-01-12 17:42 GameOgre
            很簡單的題目,按照基本語義就很容易理解,非要從低層機制去解釋,實在有點過分了,正如樓上所說,就是一個簡單的鏈表啊。是想說遞歸機制嗎?  回復  更多評論
              
            # re: 一道有意思的題目,大家看看輸出:)  2009-01-12 21:58 bneliao
            這個會有內(nèi)存泄露的!!
            除了第一個”對象“是在棧上實現(xiàn)之外,后面它指針指向的對象都是通過new的方式在堆上實現(xiàn),而c++似乎沒有刪除堆上指針指向的對象能力(這個”堆上“資源的回收可以用gc來實現(xiàn));其實這個遞歸實現(xiàn)有點像函數(shù)式編程里的”閉包“實現(xiàn)。
            有錯誤,請高手指正。
              回復  更多評論
              
            # re: 一道有意思的題目,大家看看輸出:)  2009-01-13 09:58 zuhd
            樓上說的內(nèi)存泄漏是存在的,泄漏了4* (4 + 4) = 32 BYTE,在后面的4次只是刪除了成員指針,但沒有刪除自己(sizeof(B)),還有這種構(gòu)造函數(shù)的嵌套是極不提倡的,如果基類的成員不是int,是int*的話,估計會讓人很頭痛的  回復  更多評論
              
            # re: 一道有意思的題目,大家看看輸出:)  2009-01-13 13:23 alexandercer
            事實上,是沒有內(nèi)存泄漏的,因為用了'~B(){delete pB;}',這樣,針對堆上的內(nèi)存會被依次析構(gòu)并刪除內(nèi)存。 而且,就算沒有delete pB; 泄漏也是可控的,因為是寫在main里面的,系統(tǒng)會幫你回收這部分的內(nèi)存的。

            內(nèi)存的事情,就是那樣啦~~比較容易頭痛的。。。  回復  更多評論
              
            # re: 一道有意思的題目,大家看看輸出:)  2009-01-13 13:47 夢在天涯
            仔細看了下,這樣的結(jié)果就是正常的啊,瘋了!  回復  更多評論
              
            # re: 一道有意思的題目,大家看看輸出:)  2009-01-13 15:30 了修
            哈哈 個人感覺這個東西比較有意思 自然也有高人覺著無聊
            關于內(nèi)存泄漏的事情沒有追 沒有機器哈
            大家踴躍討論啊  回復  更多評論
              
            # re: 一道有意思的題目,大家看看輸出:)  2009-01-13 16:03 alexandercer
            我又試了一下,寫了點東東內(nèi)嵌,輸出調(diào)用過程,大家參考參考:

            main [called by other code]
            A::A(int) [called by other code]
            B::B(int) test.cpp, 28
            A::A(int) [called by other code]
            B::B(int) test.cpp, 15
            A::A(int) [called by other code]
            B::B(int) test.cpp, 15
            A::A(int) [called by other code]
            B::B(int) test.cpp, 15
            A::A(int) [called by other code]
            B::B(int) test.cpp, 15
            B::Display() test.cpp, 29
            4
            B::Display() test.cpp, 21
            3
            B::Display() test.cpp, 21
            2
            B::Display() test.cpp, 21
            1
            B::Display() test.cpp, 21
            0
            B::~B() [called by other code]
            B::~B() test.cpp, 17
            B::~B() test.cpp, 17
            B::~B() test.cpp, 17
            B::~B() test.cpp, 17


            我不知道格式會不會出問題。。。。大家將就。。。  回復  更多評論
              
            # re: 一道有意思的題目,大家看看輸出:)  2009-01-13 16:07 alexandercer
            格式果然有問題,俺的縮進都沒有了~~~~暈。。。。

              回復  更多評論
              
            # re: 一道有意思的題目,大家看看輸出:)  2009-01-13 16:28 alexandercer
            更加詳細的調(diào)用stack:

            A(int n) @ 7 @ test-noinsure.cpp
            B(int n) @ 19 @ test-noinsure.cpp
            A(int n) @ 7 @ test-noinsure.cpp
            B(int n) @ 19 @ test-noinsure.cpp
            A(int n) @ 7 @ test-noinsure.cpp
            B(int n) @ 19 @ test-noinsure.cpp
            A(int n) @ 7 @ test-noinsure.cpp
            B(int n) @ 19 @ test-noinsure.cpp
            A(int n) @ 7 @ test-noinsure.cpp
            B(int n) @ 19 @ test-noinsure.cpp
            B::Display() @ 27 @ test-noinsure.cpp
            4
            B::Display() @ 27 @ test-noinsure.cpp
            3
            B::Display() @ 27 @ test-noinsure.cpp
            2
            B::Display() @ 27 @ test-noinsure.cpp
            1
            B::Display() @ 27 @ test-noinsure.cpp
            0
            ~B() @ 23 @ test-noinsure.cpp
            ~B() @ 23 @ test-noinsure.cpp
            ~B() @ 23 @ test-noinsure.cpp
            ~B() @ 23 @ test-noinsure.cpp
            ~B() @ 23 @ test-noinsure.cpp
            ~A() @ 9 @ test-noinsure.cpp
            ~A() @ 9 @ test-noinsure.cpp
            ~A() @ 9 @ test-noinsure.cpp
            ~A() @ 9 @ test-noinsure.cpp
            ~A() @ 9 @ test-noinsure.cpp


              回復  更多評論
              
            # re: 一道有意思的題目,大家看看輸出:)  2009-01-18 11:45 witer666
            那樓主是不是要Delete[] pB呢?  回復  更多評論
              
            # re: 一道有意思的題目,大家看看輸出:)  2009-01-22 18:11 Zero
            一個簡單的單向鏈表。
            析構(gòu)函數(shù)中delete操作,不斷的調(diào)用下一個節(jié)點的析構(gòu)函數(shù)和釋放堆空間。
            結(jié)論是沒有內(nèi)存泄漏。
              回復  更多評論
              
            无码人妻久久一区二区三区| 色婷婷噜噜久久国产精品12p| 久久伊人精品一区二区三区| 国产精品99久久久精品无码| 亚洲人成网亚洲欧洲无码久久| 日产精品久久久久久久| 色综合久久无码中文字幕| 97久久久久人妻精品专区| 久久精品国产清自在天天线| 久久精品国产亚洲av麻豆蜜芽 | 2021最新久久久视精品爱| 久久精品中文无码资源站| 国产精品久久久久久福利69堂| 国产无套内射久久久国产| 欧美伊人久久大香线蕉综合| 久久成人精品视频| 99久久香蕉国产线看观香| 久久国产免费观看精品| 伊人久久精品影院| 国产叼嘿久久精品久久| 国产香蕉久久精品综合网| 国产69精品久久久久9999| 久久婷婷是五月综合色狠狠| 热re99久久精品国产99热| 亚洲人成网亚洲欧洲无码久久| 久久精品成人一区二区三区| 久久99国产综合精品免费| 久久受www免费人成_看片中文| 99久久精品国产毛片| 国产V亚洲V天堂无码久久久| 国内精品伊人久久久影院| 日本精品久久久久影院日本| 久久综合狠狠色综合伊人| 久久国产精品无码HDAV| 亚洲国产精品无码久久久蜜芽| 久久久久人妻一区精品果冻| 国产成人精品综合久久久| 狠狠狠色丁香婷婷综合久久五月| 亚洲色欲久久久综合网东京热| 要久久爱在线免费观看| 中文字幕久久精品|