• <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>
            面對現實,超越自己
            逆水行舟,不進則退
            posts - 269,comments - 32,trackbacks - 0
            C++函數后面后加到關鍵字throw(something)限制,是對這個函數的異常安全性作出限制。

            void f() throw()  表示f不允許拋出任何異常,即f是異常安全的。

            void f() throw(...) 表示f可以拋出任何形式的異常。

            void f() throw(exceptionType); 表示f只能拋出exceptionType類型的異常。

            引別人的一個笑話:

            throw() 大概會說:“噢,不管你拋什么,就是不準拋。。”
            throw(...) 呵呵一笑,滿臉慈祥:“拋吧拋吧,盡情地拋吧。。。”
            throw(type) 一聽急了:“那可不行,要拋也只能拋我的香煙頭,否則要是不小心把俺祖傳的金戒指拋掉就太虧了。。。”

            關于C++的異常傳遞有三種方法:

            1.傳值(by value)

            傳值的過程中會產生臨時對象的拷貝,不能解決多態的問題,如下:myexception繼承exception,但是但確無法被正確的調用myexception的方法,造成對異常對象的切割。
             1 class myexception:public exception{
             2 public:
             3     virtual const char* what() throw();
             4 };
             5 const char* myexception::what(){
             6     return "myException";
             7 }
             8 class A{
             9 public:
            10     A(){}
            11     void f() throw(){
            12         throw myexception();
            13     }
            14 };
            15 int main(){
            16     A a;
            17     try{
            18         a.f();
            19     }catch(exception exc){
            20         cout<<exc.what();
            21     }
            22 }

            運行結果:UnKnown exceptions

            程序執行是會調用exception的what方法,而不是myexception的what方法。

            2.傳指針(by pointer)

            指針可以實現多態,但往往會將臨時對象的地址作為指針傳出去,出現懸掛指針錯誤。如果在堆上分配內存空間,又往往不知道何時刪除對象,出現to be or not to be的錯誤。

            結果顯示:myException
             1 class myexception:public exception{
             2 public:
             3     virtual const char * what() const;
             4 };
             5 const char* myexception::what() const{
             6     return "myException";
             7 }
             8 class A{
             9 public:
            10     A(){}
            11     void f() throw(){
            12         throw new myexception();
            13     }
            14 };
            15 int main(){
            16     A a;
            17     try{
            18         a.f();
            19     }catch(exception* pexc){
            20         cout<<pexc->what();
            21         delete pexc;
            22     }
            23 }

            3.傳引用(by reference)

            傳引用是最好的方法,可以克服前面的兩個問題。

            程序結果顯示:myException

             1 class myexception:public exception{
             2 public:
             3     virtual const char * what() const;
             4 };
             5 const char* myexception::what() const{
             6     return "myException";
             7 }
             8 class A{
             9 public:
            10     A(){}
            11     void f() throw(){
            12         throw myexception();
            13     }
            14 };
            15 int main(){
            16     A a;
            17     try{
            18         a.f();
            19     }catch(exception& exc){
            20         cout<<exc.what();
            21     }
            22 }

            本文轉自:http://www.cnblogs.com/CUCmehp/archive/2009/01/12/1374320.html
            posted on 2012-10-24 10:20 王海光 閱讀(571) 評論(0)  編輯 收藏 引用 所屬分類: C++
            色狠狠久久综合网| 国产精品久久久久9999高清| 久久久久久久综合日本| 久久久青草青青国产亚洲免观| 久久青青草原精品国产软件| 一本综合久久国产二区| 国产综合久久久久| 久久久久久青草大香综合精品| 99久久精品国产一区二区| 青青草国产精品久久| 亚洲午夜久久久影院伊人| 久久久精品波多野结衣| 国产亚洲综合久久系列| 思思久久好好热精品国产| 91久久九九无码成人网站| 国内精品九九久久精品| 免费精品久久久久久中文字幕| 国产精品久久成人影院| 久久伊人精品一区二区三区| 精品久久人人做人人爽综合| 精品熟女少妇av免费久久| 亚洲香蕉网久久综合影视| 合区精品久久久中文字幕一区| 亚洲一区中文字幕久久| 97久久精品人妻人人搡人人玩| 亚洲人成网亚洲欧洲无码久久| 久久亚洲中文字幕精品一区四| 91精品国产综合久久四虎久久无码一级| 精品久久久无码人妻中文字幕| 性做久久久久久久久老女人| 久久久精品视频免费观看| 久久久国产精品| 亚洲美日韩Av中文字幕无码久久久妻妇 | 一个色综合久久| 亚洲国产综合久久天堂| 久久中文精品无码中文字幕| 久久亚洲国产成人影院网站| 久久福利片| 日韩十八禁一区二区久久| 一本一道久久a久久精品综合 | 精品久久久久久|