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

C++分析研究  
C++
日歷
<2014年1月>
2930311234
567891011
12131415161718
19202122232425
2627282930311
2345678
統計
  • 隨筆 - 92
  • 文章 - 4
  • 評論 - 4
  • 引用 - 0

導航

常用鏈接

留言簿

隨筆檔案

文章檔案

搜索

  •  

最新評論

閱讀排行榜

評論排行榜

 

  構造函數中拋出的異常

  1、標準C++中定義構造函數是一個對象構建自己,分配所需資源的地方,一旦構造函數執行完畢,則表明這個對象已經誕生了,有自己的行為和內部的運行狀態,之后還有對象的消亡過程(析構函數的執行)。可誰能保證對象的構造過程一定能成功呢?說不定系統當前的某個資源不夠,導致對象不能完全構建好自己(人都有畸形兒,更何況別的呢?朋友們!是吧!),因此通過什么方法來表明對象的構造失敗了呢?C++程序員朋友們知道,C++中的構造函數是沒有返回值的,所以不少關于C++編程方面的書上得出結論:"因為構造函數沒有返回值,所以通知對象的構造失敗的唯一方法那就是在構造函數中拋出異常".主人公阿愚非常不同意這種說法,誰說的,便不信邪!雖然C++標準規定構造函數是沒有返回值,可我們知道每個函數實際上都會有一個返回值的,這個值被保存在eax寄存器中,因此實際上是有辦法通過編程來實現構造函數返回一個值給上層的對象創建者。當然即便是構造函數真的不能有返回值,我們也可以通過一個指針類型或引用類型的出參來獲知對象的構造過程的狀態。示例如下:

  class MyTest_Base

  {

  public:

  MyTest_Base (int& status)

  {

  //do other job

  // 由于資源不夠,對象構建失敗

  // 把status置0,通知對象的構建者

  status = 0;

  }

  protected:

  };

  void main()

  {

  int status;

  MyTest_Base obj1(status);

  // 檢查對象的構建是否成功

  if(status ==0) cout 《 "對象構建失敗" 《 endl;

  }

  程序運行的結果是:

  對象構建失敗

  是啊!上面我們不也得到了對象構造的成功與否的信息了嗎?可大家有沒有覺得這當中有點問題?主人公阿愚建議大家在此停留片刻,仔細想想它會有什么問題?OK!也許大家都知道了問題的所在,來驗證一下吧!

  class MyTest_Base

  {

  public:

  MyTest_Base (int& status)

  {

  //do other job

  // 由于資源不夠,對象構建失敗

  // 把status置0,通知對象的構建者

  status = 0;

  }

  virtual ~ MyTest_Base ()

  {

  cout 《 "銷毀一個MyTest_Base類型的對象" 《 endl;

  }

  protected:

  };

  void main()

  {

  int status;

  MyTest_Base obj1(status);

  // 檢查對象的構建是否成功

  if(status ==0) cout 《 "對象構建失敗" 《 endl;

  }

  程序運行的結果是:

  對象構建失敗

  銷毀一個MyTest_Base類型的對象

  沒錯,對象的析構函數被運行了,這與C++標準中所規定的面向對象的一些特性是有沖突的。一個對象都沒有完成自己的構造,又何來析構!好比一個夭折的畸形兒還沒有出生,又何來死之言。因此這種方法是行不通的。那怎么辦?那就是上面那個結論中的后一句話是對的,通知對象的構造失敗的唯一方法那就是在構造函數中拋出異常,但原因卻不是由于構造函數沒有返回值而造成的。恰恰相反,C++標準中規定構造函數沒有返回值正是由于擔心很容易與面向對象的一些特性相沖突,因此干脆來個規定,構造函數不能有返回值(主人公阿愚的個人理解,有不同意見的朋友歡迎討論)。

  2、構造函數中拋出異常將導致對象的析構函數不被執行。哈哈^-^,阿愚很開心,瞧瞧!如果沒有C++的異常處理機制鼎立支持,C++中的面向對象特性都無法真正實現起來,C++標準總不能規定所有的對象都必須成功構造吧!這也太理想化了,也許只有等到共產主義社會實現的那一天(CPU可以隨便拿,內存可以隨便拿,所有的資源都是你的!)才說不定有可能·····,所以說C++的異常處理和面向對象確實是誰也離不開誰。當然示例還是要看一下,如下:

  class MyTest_Base

  {

  public:

  MyTest_Base (string name = "") : m_name(name)

  {

  throw std::exception("在構造函數中拋出一個異常,測試!");

  cout 《 "構造一個MyTest_Base類型的對象,對象名為:"《m_name 《 endl;

  }

  virtual ~ MyTest_Base ()

  {

  cout 《 "銷毀一個MyTest_Base類型的對象,對象名為:"《m_name 《 endl;

  }

  void Func() throw()

  {

  throw std::exception("故意拋出一個異常,測試!");

  }

  void Other() {}

  protected:

  string m_name;

  };

  void main()

  {

  try

  {

  // 對象構造時將會拋出異常

  MyTest_Base obj1("obj1");

  obj1.Func();

  obj1.Other();

  }

  catch(std::exception e)

  {

  cout 《 e.what() 《 endl;

  }

  catch(…)

  {

  cout 《 "unknow exception"《 endl;

  }

  }

  程序的運行結果將會驗證:"構造函數中拋出異常將導致對象的析構函數不被執行"

  3、是不是到此,關于構造函數中拋出異常的處理的有關討論就能結束了呢?非也!非也!主人公阿愚還有進一步的故事需要講述!來看一個更復雜一點的例子吧!如下:

  class MyTest_Base

  {

  public:

  MyTest_Base (string name = "") : m_name(name)

  {

  cout 《 "構造一個MyTest_Base類型的對象,對象名為:"《m_name 《 endl;

  }

  virtual ~ MyTest_Base ()

  {

  cout 《 "銷毀一個MyTest_Base類型的對象,對象名為:"《m_name 《 endl;

  }

  void Func() throw()

  {

  throw std::exception("故意拋出一個異常,測試!");

  }

  void Other() {}

  protected:

  string m_name;

  };

  class MyTest_Parts

  {

  public:

  MyTest_Parts ()

  {

  cout 《 "構造一個MyTest_Parts類型的對象" 《 endl;

  }

  virtual ~ MyTest_Parts ()

  {

  cout 《 "銷毀一個MyTest_Parts類型的對象"《 endl;

  }

  };

  class MyTest_Derive : public MyTest_Base

  {

  public:

  MyTest_Derive (string name = "") : m_component(), MyTest_Base(name)

  {

  throw std::exception("在MyTest_Derive對象的構造函數中拋出了一個異常!");

  cout 《 "構造一個MyTest_Derive類型的對象,對象名為:"《m_name 《 endl;

  }

  virtual ~ MyTest_Derive ()

  {

  cout 《 "銷毀一個MyTest_Derive類型的對象,對象名為:"《m_name 《 endl;

  }

  protected:

  MyTest_Parts m_component;

  };

  void main()

  {

  try

  {

  // 對象構造時將會拋出異常

  MyTest_Derive obj1("obj1");

  obj1.Func();

  obj1.Other();

  }

  catch(std::exception e)

  {

  cout 《 e.what() 《 endl;

  }

  catch(…)

  {

  cout 《 "unknow exception"《 endl;

  }

  }

  程序運行的結果是:

  構造一個MyTest_Base類型的對象,對象名為:obj1

  構造一個MyTest_Parts類型的對象

  銷毀一個MyTest_Parts類型的對象

  銷毀一個MyTest_Base類型的對象,對象名為:obj1

  在MyTest_Derive對象的構造函數中拋出了一個異常!

  上面這個例子中,MyTest_Derive從MyTest_Base繼承,同時MyTest_Derive還有一個MyTest_Parts類型的成員變量。現在MyTest_Derive構造的時候,是在父類MyTest_Base已構造完畢和MyTest_Parts類型的成員變量m_component也已構造完畢之后,再拋出了一個異常,這種情況稱為對象的部分構造。是的,這種情況很常見,對象總是由不斷的繼承或不斷的聚合而來,對象的構造過程實際上是這些所有的子對象按規定順序的構造過程,其中這些過程中的任何一個子對象在構造時發生異常,對象都不能說自己完成了全部的構造過程,因此這里就有一個棘手的問題,當發生對象的部分構造時,對象將析構嗎?如果時,又將如何析構呢?托福答案

  從運行結果可以得出如下結論:

  (1) 對象的部分構造是很常見的,異常的發生點也完全是隨機的,程序員要謹慎處理這種情況;

  (2) 當對象發生部分構造時,已經構造完畢的子對象將會逆序地被析構(即異常發生點前面的對象);而還沒有開始構建的子對象將不會被構造了(即異常發生點后面的對象),當然它也就沒有析構過程了;還有正在構建的子對象和對象自己本身將停止繼續構建(即出現異常的對象),并且它的析構是不會被執行的。sat答案

  構造函數中拋出異常時概括性總結

  (1) C++中通知對象構造失敗的唯一方法那就是在構造函數中拋出異常;

  (2) 構造函數中拋出異常將導致對象的析構函數不被執行;

  (3) 當對象發生部分構造時,已經構造完畢的子對象將會逆序地被析構;

  (4) 其是還是那句話, "C++的異常處理不會破壞任何一條面向對象的特性!",因此主人公阿愚再次建議朋友們,牢牢記住這一條!

posted on 2014-01-10 21:30 HAOSOLA 閱讀(662) 評論(0)  編輯 收藏 引用
 
Copyright © HAOSOLA Powered by: 博客園 模板提供:滬江博客
PK10開獎 PK10開獎
青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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>
            在线播放中文一区| 午夜精品免费| 亚洲欧美另类在线观看| 亚洲精品在线一区二区| 亚洲激情女人| 一本高清dvd不卡在线观看| 国产精品99久久久久久人| 这里只有精品视频| 亚洲欧美国产一区二区三区| 久久精品成人一区二区三区| 美女国产精品| 99国产精品国产精品久久| 亚洲自拍都市欧美小说| 久久久91精品国产一区二区三区| 久久精品国产91精品亚洲| 欧美国产日本在线| 国产精品久久久久久久久婷婷| 国产日韩欧美一区二区三区在线观看 | 欧美777四色影视在线| 你懂的视频欧美| 欧美视频手机在线| 黑丝一区二区三区| 亚洲天堂av在线免费| 久久影院亚洲| 在线视频欧美日韩精品| 久久久.com| 国产精品久久久久国产a级| 一区在线观看视频| 亚洲欧美精品suv| 欧美大片免费久久精品三p | 9人人澡人人爽人人精品| 亚洲欧美综合精品久久成人| 欧美a级大片| 国产一区二区三区四区五区美女 | 欧美韩日高清| 国产亚洲欧美色| 亚洲天堂av高清| 亚洲成人在线网| 一区二区三区精品视频| 久久中文久久字幕| 国产视频一区在线观看一区免费| 日韩一级在线| 欧美国产日韩亚洲一区| 午夜综合激情| 国产精品乱子久久久久| 久久久久高清| 欧美日韩精品一区二区天天拍小说 | 久久久综合免费视频| 欧美午夜精品久久久久久浪潮| 一区在线影院| 久久精品国产清高在天天线| 99一区二区| 欧美成人午夜激情在线| 伊人婷婷欧美激情| 久久久噜噜噜久噜久久 | 欧美日韩国产综合在线| 亚洲黄色三级| 欧美成人首页| 蜜臀av国产精品久久久久| 国外精品视频| 久久香蕉国产线看观看av| 欧美一区二区视频在线观看2020 | 亚洲色无码播放| 亚洲精品乱码久久久久久蜜桃91| 欧美成人自拍视频| 日韩视频一区二区在线观看| 亚洲国产视频一区| 欧美精品久久久久a| 99亚洲一区二区| 日韩一区二区高清| 国产精品久久久久7777婷婷| 亚洲欧美三级伦理| 欧美一区二区福利在线| 一区二区三区在线视频观看| 欧美a级理论片| 欧美黄色一级视频| 亚洲香蕉视频| 欧美在线观看一区二区三区| 在线观看中文字幕不卡| 亚洲二区在线视频| 欧美三级不卡| 久久亚洲国产精品日日av夜夜| 久久综合久久综合九色| 99国产精品国产精品毛片| 亚洲图片激情小说| 亚洲第一精品久久忘忧草社区| 亚洲欧洲精品一区二区三区不卡 | 国产精品久久影院| 久久久xxx| 欧美成人a视频| 亚洲淫片在线视频| 久久久精品一区二区三区| 日韩午夜视频在线观看| 亚洲天堂成人| 亚洲国产成人av| 一本一道久久综合狠狠老精东影业 | 欧美刺激性大交免费视频| 欧美人与性动交cc0o| 欧美在线免费观看| 欧美韩日精品| 久久人体大胆视频| 国产精品成人一区二区| 欧美电影在线免费观看网站| 国产精品免费看久久久香蕉| 欧美大片在线观看一区| 国产精品久久久久9999吃药| 免费不卡在线观看av| 国产精品国产三级国产aⅴ入口 | 国产精品久久久久久久免费软件| 久久亚洲精品一区二区| 欧美午夜剧场| 亚洲国产精品成人精品| 国产亚洲一区二区在线观看| 夜夜夜久久久| 亚洲精品一区在线| 久久久久综合网| 欧美在线免费视屏| 欧美午夜精品久久久久久浪潮 | 久久久91精品国产一区二区精品| 欧美日韩成人综合天天影院| 免费成人性网站| 国产精品专区一| 亚洲免费精彩视频| 日韩午夜免费| 欧美国产在线电影| 欧美激情一区二区三区成人 | 国产精品欧美日韩一区| 亚洲精品乱码| 日韩视频在线一区| 猛男gaygay欧美视频| 久久天堂av综合合色| 国产视频一区免费看| 亚洲一区二区黄| 亚洲影院在线观看| 欧美天天在线| 一本久久综合| 亚洲专区一二三| 国产精品福利在线观看| 亚洲精选国产| 亚洲一区二区三区在线观看视频| 欧美极品欧美精品欧美视频| 亚洲国产精品成人| 9人人澡人人爽人人精品| 欧美精品一区二区三区蜜桃| 亚洲精品乱码久久久久久黑人| 亚洲日韩欧美视频一区| 欧美韩日一区| 中文久久精品| 欧美诱惑福利视频| 国产一区二区剧情av在线| 欧美自拍丝袜亚洲| 亚洲高清二区| 一区二区高清视频| 国产精品嫩草久久久久| 翔田千里一区二区| 91久久精品国产| 欧美日韩国产亚洲一区| 一区二区三区精品久久久| 欧美一区不卡| 黑人巨大精品欧美黑白配亚洲 | 男人天堂欧美日韩| 亚洲精品国产精品乱码不99按摩| 欧美黄网免费在线观看| 在线视频亚洲欧美| 久久久综合网| 一本色道久久88综合日韩精品| 欧美色视频一区| 久久国产加勒比精品无码| 亚洲电影免费观看高清完整版在线观看| 亚洲欧洲一区二区在线播放 | 免费成年人欧美视频| 日韩午夜黄色| 久久久久久亚洲精品杨幂换脸 | 久久激情综合网| 亚洲国产第一| 欧美自拍偷拍午夜视频| 亚洲片国产一区一级在线观看| 欧美三级日本三级少妇99| 久久久999| 亚洲一区尤物| 亚洲国产日韩欧美一区二区三区| 午夜激情久久久| 亚洲精品在线免费观看视频| 国产日韩av高清| 欧美激情综合在线| 久久国产婷婷国产香蕉| 艳妇臀荡乳欲伦亚洲一区| 久久免费99精品久久久久久| 在线一区亚洲| 亚洲茄子视频| 国内精品免费在线观看| 欧美性猛交xxxx乱大交退制版| 久久综合九色欧美综合狠狠| 亚洲一区二区三区色| 亚洲国产精品成人综合| 久久最新视频| 久久在线视频| 欧美在线视频免费播放| 亚洲天堂久久| 一区二区日韩|