• <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 王海光 閱讀(577) 評論(0)  編輯 收藏 引用 所屬分類: C++
            久久91综合国产91久久精品| 国产精品综合久久第一页| 99久久国产亚洲综合精品| 久久久久亚洲AV无码观看| 久久久免费精品re6| 国产精品一区二区久久精品无码| 青春久久| 久久99精品国产99久久| 久久精品亚洲AV久久久无码| 大伊人青草狠狠久久| 偷窥少妇久久久久久久久| 99国产精品久久久久久久成人热| 久久久久国产成人精品亚洲午夜| 99久久精品免费看国产一区二区三区 | 99久久免费国产精品特黄| 97久久国产亚洲精品超碰热 | 精品国产福利久久久| 久久久久久亚洲精品影院| 久久亚洲欧美日本精品| 久久精品国产99久久久古代| 九九99精品久久久久久| 久久影院综合精品| 97视频久久久| 国产精品久久久久久久人人看| 久久电影网一区| 77777亚洲午夜久久多喷| 亚洲av成人无码久久精品| 区亚洲欧美一级久久精品亚洲精品成人网久久久久 | 思思久久精品在热线热| 久久久免费观成人影院| 国产成人精品久久亚洲| A狠狠久久蜜臀婷色中文网| 77777亚洲午夜久久多人| 久久99九九国产免费看小说| 久久无码国产| 一个色综合久久| 亚洲精品无码久久毛片| 久久综合偷偷噜噜噜色| 久久精品亚洲AV久久久无码| 无码国内精品久久人妻| 色婷婷久久综合中文久久蜜桃av|