青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品

隨筆 - 2  文章 - 17  trackbacks - 0
<2025年9月>
31123456
78910111213
14151617181920
21222324252627
2829301234
567891011

常用鏈接

留言簿(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),同時棧要維護(hù)現(xiàn)場,
存儲 val=4,pb=new B(3) 產(chǎn)生的對象地址設(shè)為 pb1 以及函數(shù)的下個語句
地址,此時是‘}’就相當(dāng)于return。
*/

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

b.Display();
調(diào)用此句,顯然此時 val=4,pb=pb1 pb1->display(); 此時 val 應(yīng)該是
等于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 末檐兒@了修 閱讀(1499) 評論(16)  編輯 收藏 引用

FeedBack:
# re: 一道有意思的題目,大家看看輸出:) [未登錄] 2009-01-12 12:33 dd
在創(chuàng)建對象b后,b的成員變量pB是指向的B(3)這個對象的地址,那么調(diào)用Display,不就是顯示4和3嗎?  回復(fù)  更多評論
  
# 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。  回復(fù)  更多評論
  
# re: 一道有意思的題目,大家看看輸出:)  2009-01-12 13:38 yu
這里的解釋是否有不合理的地方?

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


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

@yu
  回復(fù)  更多評論
  
# re: 一道有意思的題目,大家看看輸出:)  2009-01-12 15:23 ss
跟現(xiàn)場保護(hù)什么事?
這不就像建了個鏈表,一順打印出節(jié)點值嗎。  回復(fù)  更多評論
  
# re: 一道有意思的題目,大家看看輸出:)  2009-01-12 17:42 GameOgre
很簡單的題目,按照基本語義就很容易理解,非要從低層機制去解釋,實在有點過分了,正如樓上所說,就是一個簡單的鏈表啊。是想說遞歸機制嗎?  回復(fù)  更多評論
  
# re: 一道有意思的題目,大家看看輸出:)  2009-01-12 21:58 bneliao
這個會有內(nèi)存泄露的!!
除了第一個”對象“是在棧上實現(xiàn)之外,后面它指針指向的對象都是通過new的方式在堆上實現(xiàn),而c++似乎沒有刪除堆上指針指向的對象能力(這個”堆上“資源的回收可以用gc來實現(xiàn));其實這個遞歸實現(xiàn)有點像函數(shù)式編程里的”閉包“實現(xiàn)。
有錯誤,請高手指正。
  回復(fù)  更多評論
  
# re: 一道有意思的題目,大家看看輸出:)  2009-01-13 09:58 zuhd
樓上說的內(nèi)存泄漏是存在的,泄漏了4* (4 + 4) = 32 BYTE,在后面的4次只是刪除了成員指針,但沒有刪除自己(sizeof(B)),還有這種構(gòu)造函數(shù)的嵌套是極不提倡的,如果基類的成員不是int,是int*的話,估計會讓人很頭痛的  回復(fù)  更多評論
  
# 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)存的事情,就是那樣啦~~比較容易頭痛的。。。  回復(fù)  更多評論
  
# re: 一道有意思的題目,大家看看輸出:)  2009-01-13 13:47 夢在天涯
仔細(xì)看了下,這樣的結(jié)果就是正常的啊,瘋了!  回復(fù)  更多評論
  
# re: 一道有意思的題目,大家看看輸出:)  2009-01-13 15:30 了修
哈哈 個人感覺這個東西比較有意思 自然也有高人覺著無聊
關(guān)于內(nèi)存泄漏的事情沒有追 沒有機器哈
大家踴躍討論啊  回復(fù)  更多評論
  
# 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


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

  回復(fù)  更多評論
  
# re: 一道有意思的題目,大家看看輸出:)  2009-01-13 16:28 alexandercer
更加詳細(xì)的調(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


  回復(fù)  更多評論
  
# re: 一道有意思的題目,大家看看輸出:)  2009-01-18 11:45 witer666
那樓主是不是要Delete[] pB呢?  回復(fù)  更多評論
  
# re: 一道有意思的題目,大家看看輸出:)  2009-01-22 18:11 Zero
一個簡單的單向鏈表。
析構(gòu)函數(shù)中delete操作,不斷的調(diào)用下一個節(jié)點的析構(gòu)函數(shù)和釋放堆空間。
結(jié)論是沒有內(nèi)存泄漏。
  回復(fù)  更多評論
  

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


青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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>
              av72成人在线| 精品999在线播放| 午夜影视日本亚洲欧洲精品| 这里只有精品视频在线| 亚洲成人资源网| 亚洲第一区在线| 91久久久亚洲精品| 在线亚洲免费视频| 欧美一区二区三区喷汁尤物| 欧美一级淫片播放口| 久久久久欧美精品| 欧美国产一区二区在线观看| 亚洲精品国产精品国自产观看| 亚洲国产精品99久久久久久久久| 日韩一区二区精品葵司在线| 欧美影院一区| 女主播福利一区| 欧美日韩综合网| 国产一区二区三区久久 | 亚洲国产精品第一区二区| 影音先锋亚洲电影| 99re这里只有精品6| 欧美主播一区二区三区美女 久久精品人 | 一本色道久久综合狠狠躁的推荐| 亚洲欧美文学| 欧美日韩综合在线免费观看| 黄色一区二区在线| 亚洲香蕉成视频在线观看| 久久久亚洲高清| 一区二区三区精品国产| 久久一区亚洲| 国产精品综合网站| 亚洲美女精品成人在线视频| 亚洲男女自偷自拍图片另类| 欧美国产极速在线| 国产综合精品| 亚洲女人小视频在线观看| 亚洲国产精品t66y| 久热精品视频在线观看| 国产精品入口66mio| 99精品久久久| 欧美成人黄色小视频| 午夜精品区一区二区三| 欧美日韩在线一区二区三区| 亚洲日本电影| 女主播福利一区| 欧美在线观看一区二区三区| 国产精品免费久久久久久| 亚洲裸体俱乐部裸体舞表演av| 久久天堂国产精品| 亚洲一区二区在线观看视频| 国产精品成人一区二区网站软件| 一本综合精品| 亚洲一区二区三区涩| 欧美高清视频一区二区三区在线观看 | 国产精品网站一区| 亚洲青涩在线| 免费欧美在线视频| 久久疯狂做爰流白浆xx| 国产美女扒开尿口久久久| 一区二区三区精品| 亚洲美女黄网| 欧美亚洲第一页| 亚洲午夜成aⅴ人片| 夜夜嗨av一区二区三区四区| 欧美三区不卡| 午夜精品福利电影| 欧美一级久久久| 国产在线乱码一区二区三区| 久久裸体艺术| 久久久久久久成人| 亚洲国产视频直播| 亚洲精品欧美| 欧美成人免费网| 日韩视频专区| 一区二区三区久久久| 国产精品美女www爽爽爽视频| 欧美在线网站| 午夜视频在线观看一区二区| 激情久久影院| 亚洲精选一区| 国产日韩亚洲欧美| 久久久久久网| 欧美大尺度在线观看| 亚洲欧美在线磁力| 久久久久久9999| 一区二区三区四区在线| 欧美亚洲三区| 日韩一级大片| 午夜在线观看免费一区| 最新中文字幕一区二区三区| 亚洲视频成人| 亚洲黄色有码视频| 亚洲一区网站| 亚洲国产高清高潮精品美女| av成人免费| 亚洲福利视频免费观看| 亚洲色在线视频| 亚洲国产精品成人综合| 国产精品99久久久久久宅男| 在线播放中文字幕一区| 国产精品99久久久久久久vr| 亚洲东热激情| 一级日韩一区在线观看| 国产欧美一区二区三区在线看蜜臀| 欧美激情亚洲激情| 国产亚洲综合在线| 在线综合亚洲| 亚洲激情视频网| 午夜伦欧美伦电影理论片| 亚洲国内高清视频| 欧美一区二区三区久久精品| 亚洲视频一区在线观看| 久久久九九九九| 亚洲欧美日韩中文播放| 欧美激情一区二区三区全黄| 正在播放日韩| 欧美亚洲综合在线| 日韩一二三区视频| 美女精品一区| 久久亚洲国产成人| 亚洲大胆在线| 狠狠干综合网| 性色一区二区三区| 香蕉国产精品偷在线观看不卡| 欧美经典一区二区三区| 亚洲成人资源| 91久久久精品| 乱码第一页成人| 老司机一区二区三区| 国产一区视频网站| 亚洲欧美一区二区精品久久久| 亚洲少妇自拍| 欧美色欧美亚洲高清在线视频| 亚洲国产mv| 亚洲人成人99网站| 欧美插天视频在线播放| 欧美激情一区二区三区高清视频 | 欧美激情视频在线播放| 美女性感视频久久久| 激情六月综合| 久久蜜桃资源一区二区老牛| 欧美成人激情视频| 影音先锋成人资源站| 久久婷婷国产综合精品青草| 久久综合导航| 亚洲激精日韩激精欧美精品| 欧美高潮视频| 亚洲午夜一区| 久久经典综合| 精品白丝av| 美女亚洲精品| 99ri日韩精品视频| 亚洲在线免费观看| 韩日精品视频一区| 欧美日本精品在线| 亚洲免费中文| 欧美www在线| 99热这里只有精品8| 国产精品v日韩精品| 欧美亚洲专区| 欧美激情一区二区三级高清视频| 亚洲香蕉在线观看| 一区二区三区在线视频播放| 麻豆国产va免费精品高清在线| 亚洲激情视频在线播放| 亚洲欧美日韩视频一区| 黄色成人av网| 欧美日韩免费观看一区三区 | 国语自产在线不卡| 欧美国产日韩一二三区| 亚洲小视频在线观看| 久久亚洲不卡| 亚洲欧美激情视频| 在线观看成人网| 国产精品美女久久久久久久| 美女在线一区二区| 亚洲综合导航| 亚洲日产国产精品| 久久亚洲精品视频| 久久久99精品免费观看不卡| 欧美日韩精品一区二区| 午夜激情综合网| 欧美激情按摩| 午夜精品久久久久久久99水蜜桃 | 国产欧美一区二区在线观看| 欧美成人综合网站| 亚洲欧美日韩在线不卡| 欧美激情麻豆| 久久久久国产一区二区三区四区 | 在线观看91久久久久久| 国产精品一区二区久久久久| 欧美精品久久99| 久久夜色精品一区| 久久国产精品毛片| 欧美一级二级三级蜜桃| 亚洲先锋成人| 夜夜躁日日躁狠狠久久88av| 亚洲欧洲在线一区| 亚洲第一级黄色片|