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

#include<iostream>
using std::cout;
using std::endl;
class CDust{
public:
    CDust()
    {
        cout 
<< " CDust constructor " << endl;
    }

    
~CDust()
    {

        cout 
<< " ~CFoo destructor " << endl;
    }
};


CDust A;

int main()
{
    
return 0;
}
我想類似的代碼在網(wǎng)上Google下應(yīng)該有不少
嘗試了下,在vc6.0的情況下,是沒有輸出 "~CFoo destructor", 但這并不代表 ~CDust() 沒有執(zhí)行.
在~CDust里面設(shè)置斷點,會發(fā)現(xiàn)事實上程序運行時進入了析構(gòu)函數(shù)里  // -_! 表達(dá)好牽強
本來想實在跟蹤這里開始程序發(fā)生了什么調(diào)用了什么,發(fā)現(xiàn)功底不足,完全不明白,就先打斷了
而再在' return 0 ' 語句前面加上斷點,會看到這個新加的斷點比析構(gòu)里面的斷點先到達(dá),... 
以現(xiàn)在c++的造詣和vc6.0的了解情況來看,頭痛了
為什么 return 0 后程序不是正常結(jié)束了才去執(zhí)行 全局對象的析構(gòu)?

改寫下代碼
#include<iostream.h>

class CDust{
public:
    CDust()
    {
        cout 
<< " CDust constructor " << endl;
    }

    
~CDust()
    {

        cout 
<< " ~CFoo destructor " << endl;
    }
};


CDust A;

int main()
{

    
return 0;

}

這樣用舊版本的頭文件實現(xiàn),控制臺輸出了意外的兩個調(diào)用 --- 析構(gòu)函數(shù)輸出顯示了..

是cout在頭文件的實現(xiàn)方式不同?

在dev-c++里面,運行第一代代碼
根據(jù)斷點的設(shè)置測試,也是先執(zhí)行了 main()函數(shù)里面的 return 0 才進入全局函數(shù)的析構(gòu),也能發(fā)現(xiàn)析構(gòu)函數(shù)里面的輸出被調(diào)用了,控制臺有明確的顯示
這樣一來,又不明白了...
在vc6.0里面為什么執(zhí)行了全局函數(shù)的析構(gòu)卻沒有所謂的輸出?
是因為cmd控制臺在'return 0'程序權(quán)限收回  // 好像扯到系統(tǒng)的一些混亂的舊記憶了...

網(wǎng)游了一下
找到暫時比較清晰的說法是:
   In C++, the constructor of a global object is executed before the main() function(of course after the STARTUP code), while the destructor
is invoked after the main() function. So in my humble opinion, the main() function is a bridge between the constructor and the destructor.Further more, the constructor and the destructor is the actual manager of the whole program, because they can manage all the
resources of the program(for instance, the constructor allocate memory units and the destructor free them.I'am not sure of this, any comments will be appreciated in advance.).
4)In C++, is it true that the resources obtained during the constructor and the destructor (both belong to a global object)are managed by themselves and have nothing with the main() function.Therfore, I think the main() function is not the king in C++ as it is in C. 
   //感謝提出此說法的朋友
 
  _startup才是用戶程序的起點和終點? 的確,調(diào)用_exit()函數(shù)再斷點測試,全局對象的destructor是沒有進入的機會   //長見識了

  就此先打斷... 再深入今晚就這樣完了.
  就此記錄下,以后再接觸



不小心又接觸了...
懶得開新的就集中在這里吧

在main()里面手動調(diào)用全局對象的析構(gòu), 最后程序都會執(zhí)行兩次析構(gòu)調(diào)用... 在<iostream.h>的cout這種情況下明顯,在std::cout下還得靠斷點設(shè)置才能體現(xiàn)到(vc6的情況)
     這里是一種解析
     {
      Once a destructor is invoked for an object, the object no longer exists; the behavior is undefined if the destructor is invoked for an object whose lifetime has ended. [Example: if the destructor for an automatic object is explicitly invoked, and the block is subsequently left in a manner that would ordinarily invoke implicit destruction of the object, the behavior is undefined
}
     非global static object 也會出現(xiàn)兩次調(diào)用, 區(qū)別只在與一個在main() 退出之前,一個在之后...
(的確,手工調(diào)用析構(gòu)函數(shù)的情況很少出現(xiàn)  -_! )
     如果我在析構(gòu)里面存在 釋放內(nèi)存 這一類實現(xiàn), 那第二次再次釋放不是容易出問題!!!
     以后遇到這種情況得注意檢測代碼的添加...

Feedback

# re: 關(guān)于c++對象全局對象析構(gòu)的幾點記錄  回復(fù)  更多評論   

2009-02-26 12:05 by 陳梓瀚(vczh)
說不定因為cout被析構(gòu)了,你的代碼就沒看到輸出了。

# re: 關(guān)于c++對象全局對象析構(gòu)的幾點記錄  回復(fù)  更多評論   

2009-02-27 19:28 by 藍(lán)塵
@陳梓瀚(vczh)
std::cout 被析構(gòu), 而且是只在vc6.0下面的 global static object ? 也就是說剩下的就是編譯器的實現(xiàn)問題了(網(wǎng)上的說法好像只有std::cout在vc6有這個情況)
等有時間時調(diào)試跟蹤下...
多謝提醒了

Copyright © 藍(lán)塵

青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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>
            欧美www视频在线观看| 亚洲视频导航| 亚洲清纯自拍| 久久精品国产欧美激情| 久久夜色精品国产欧美乱| 国产一区二区三区四区hd| 亚洲精品一区二区三区av| 亚洲精品乱码久久久久久按摩观 | 91久久综合| 欧美激情性爽国产精品17p| 一区二区亚洲精品| 午夜亚洲影视| 国产亚洲精品高潮| 亚洲欧美视频在线观看| 亚洲国产日韩欧美综合久久| 久久久成人网| 亚洲欧美日韩在线高清直播| 久久久精品2019中文字幕神马| 欧美不卡高清| 欧美一区深夜视频| 亚洲第一福利社区| 亚洲欧美激情视频| 国产在线乱码一区二区三区| 欧美国产精品久久| 久久久久久网| 久久xxxx| 亚洲美女视频网| 欧美午夜片在线免费观看| 亚洲久久视频| 欧美日韩ab| 亚洲综合色丁香婷婷六月图片| 毛片av中文字幕一区二区| 国产无一区二区| 亚洲专区一区| 欧美大片一区| 男同欧美伦乱| 亚洲欧美清纯在线制服| …久久精品99久久香蕉国产 | 亚洲欧美文学| 久久久噜噜噜久久狠狠50岁| 亚洲精品免费在线观看| 欧美一区二区视频在线| 亚洲激情小视频| 国产精品视频成人| 性8sex亚洲区入口| 午夜精品久久久久久99热软件| 欧美亚洲一区二区在线观看| 欧美激情第4页| 宅男噜噜噜66国产日韩在线观看| 国产视频一区免费看| 欧美三级第一页| 免费在线亚洲欧美| 日韩一区二区精品葵司在线| 玖玖精品视频| 久久成人免费电影| 国产在线播放一区二区三区| 久久久777| 久久精品色图| 亚洲欧美日韩国产中文| 国产精品www色诱视频| 一区三区视频| 精品动漫av| 国产欧美一区二区三区另类精品| 国产精品美女一区二区| 欧美成人网在线| 免费观看久久久4p| 久久精品官网| 久久精品电影| 欧美精品在线看| 久久五月天婷婷| 欧美极品在线观看| 欧美国产日韩精品| 国产欧美精品日韩精品| 亚洲国产成人porn| 亚洲蜜桃精久久久久久久| 亚洲精品欧美专区| 久久久美女艺术照精彩视频福利播放| 欧美二区在线| 亚洲尤物视频在线| 欧美日韩中文字幕在线| 亚洲图片欧美日产| 久久精品二区三区| 99天天综合性| 亚洲在线第一页| 极品尤物久久久av免费看| 午夜在线成人av| 亚洲欧美一区二区激情| 欧美噜噜久久久xxx| 欧美性大战xxxxx久久久| 亚洲国产精品www| 日韩视频在线观看| 另类激情亚洲| 一区二区在线看| 性欧美在线看片a免费观看| 亚洲国产欧洲综合997久久| 久久亚洲国产精品一区二区| 国产美女精品视频免费观看| 久久在线精品| 欧美日韩综合视频网址| 国产精品视频xxxx| 在线成人免费观看| 亚洲精品色图| 狠狠色狠狠色综合日日五| 欧美一区在线视频| 亚洲欧美日韩一区| 亚洲精品久久久久久久久久久久久| 亚洲国产精品传媒在线观看| 欧美在线地址| 国产精品毛片在线看| 久热爱精品视频线路一| 欧美理论电影在线观看| 欧美在线欧美在线| 噜噜噜在线观看免费视频日韩| 一区二区亚洲欧洲国产日韩| 免费国产一区二区| 国产日韩欧美在线观看| 亚洲欧美资源在线| 亚洲伦理精品| 一本色道久久综合狠狠躁篇的优点 | 亚洲精品1区2区| 亚洲人永久免费| 亚洲美女av在线播放| 国产精品羞羞答答| 制服丝袜亚洲播放| 亚洲国产婷婷香蕉久久久久久99| 99热这里只有精品8| 久久se精品一区精品二区| 小嫩嫩精品导航| 欧美三区在线| 亚洲欧美久久| 亚洲一区在线直播| 美女脱光内衣内裤视频久久网站| 亚洲一级特黄| 亚洲午夜精品一区二区三区他趣| 欧美日韩情趣电影| 免播放器亚洲一区| 国产精品久久二区| 亚洲女人天堂av| 欧美中文字幕| 亚洲电影免费观看高清完整版在线| 久久伊伊香蕉| 久久一二三四| 一本色道久久综合亚洲精品不| 欧美大片免费观看| 欧美mv日韩mv国产网站app| 国产精品一区二区三区观看| 亚洲欧美高清| 亚洲欧美在线一区| 国产欧美一区二区三区沐欲| 午夜精品成人在线视频| 日韩手机在线导航| 欧美另类极品videosbest最新版本| 亚洲高清在线精品| 欧美丰满高潮xxxx喷水动漫| 久久天天躁狠狠躁夜夜av| 91久久精品国产91久久| 亚洲黄页视频免费观看| 亚洲日韩中文字幕在线播放| 国产精品免费在线 | 久久久久99| 国产伦一区二区三区色一情| 欧美精品一区二区三区一线天视频 | 欧美日韩在线三区| 亚洲午夜日本在线观看| 99re在线精品| 亚洲视频精品在线| 亚洲免费视频中文字幕| 亚洲人体偷拍| 在线播放中文字幕一区| 蜜臀91精品一区二区三区| 久久国产精品色婷婷| 亚洲美女一区| 亚洲高清在线精品| 亚洲人人精品| 欧美一区日韩一区| 欧美成人免费在线观看| 久久久久在线观看| 国产综合欧美| 在线免费观看成人网| 99精品免费| 久久一区国产| 久久另类ts人妖一区二区| 久久综合综合久久综合| 亚洲人体偷拍| 亚洲视频在线一区| 亚洲欧美bt| 亚洲色无码播放| 小黄鸭精品密入口导航| 久久一区二区三区av| 久久久五月天| 国产午夜精品在线观看| 日韩亚洲欧美一区| 亚洲人成免费| 欧美中文在线免费| 欧美视频一区在线| 日韩网站在线观看| 久久综合一区| 免费人成网站在线观看欧美高清| 国产精品99久久久久久久久| 国产精品激情|