• <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>
            酸菜豬蹄的程序人生
            木下編程屯屯燙燙
            C++異常捕獲是在運(yùn)行時(shí)進(jìn)行的,但是拋出的對(duì)象卻是在編譯時(shí)確定的,編譯時(shí)會(huì)對(duì)拋出的對(duì)象上溯查找到無二義性的基類,然后拋出這個(gè)對(duì)象的引用。
             
            例如:
            #include <iostream>
            using namespace std;
            class CBase
            {
            public:
             virtual ~CBase(){};
            };
             
            class CDerived:public CBase
            {
            };
             
            void exceMaker()
            {
                throw CDerived();
            }
             
            void exceCatcher()
            {
                try
                {
                    exceMaker();
                }
                catch(CBase&)
                {
                    cout << "caught a CBase" << endl;
                }
                catch(...)
                {
                    cout << "caught else" << endl;
                }
            }
             
            int main(int argc, char** argv)
            {
                exceCatcher();
                cin.get();
                return 0;
            }
             
            運(yùn)行后將打印出:
             
            caught a CBase.
             
            編譯器進(jìn)行了類型上溯轉(zhuǎn)換,拋出的CBase的引用,如果同時(shí)捕獲CDerived&,也即在exce中加入如下代碼:
            catch(CDerived&)
            {
                cout << "caught a CDerived" << endl;
            }
            編譯時(shí)將會(huì)給出warning,說異常已經(jīng)被 catch(CBase&)捕獲,證明在編譯時(shí)進(jìn)行了轉(zhuǎn)換。
             

            而如果修改CDerived 為私有繼承CBase,整體代碼如下:
               
            #include <iostream>
            using namespace std;
            class CBase
            {
            public:
             virtual ~CBase(){};
            };
             
            class CDerived:private CBase
            {
            };
             
            void exceMaker()
            {
                throw CDerived();
            }
             
            void exceCatcher()
            {
                try
                {
                    exceMaker();
                }
                catch(CBase&)
                {
                    cout << "caught a CBase" << endl;
                }
                catch(...)
                {
                    cout << "caught else" << endl;
                }
            }
             
            int main(int argc, char** argv)
            {
                exceCatcher();
                cin.get();
                return 0;
            }   
             
            將打印出"caught else";
            因?yàn)樗接欣^承后,exceMaker函數(shù)不能對(duì)私有繼承的基類進(jìn)行上溯(private權(quán)限限制),所以拋出的異常為CDerived&,不再是CBase&.
             
            而如果這樣:
             
            #include <iostream>
            using namespace std;
            class CBase
            {
            public:
             virtual ~CBase(){};
            };
             
            class CDerived:private CBase
            {
                friend void exceMaker();
            };
             
            void exceMaker()
            {
                throw CDerived();
            }
             
            void exceCatcher()
            {
                try
                {
                    exceMaker();
                }
                catch(CBase&)
                {
                    cout << "caught a CBase" << endl;
                }
                catch(...)
                {
                    cout << "caught else" << endl;
                }
            }
             
            int main(int argc, char** argv)
            {
                exceCatcher();
                cin.get();
                return 0;
            }
             
            在VC6中將打印出"caught CBase",因?yàn)閑xceMaker是CDerived的友元函數(shù),可以訪問它的私有成員,故可以上溯到CBase&,但后續(xù)的編譯器版本已經(jīng)更正為caught else. 因?yàn)椴皇荌SA關(guān)系。
             
             
            posted on 2006-01-06 17:51 cooelaf 閱讀(3586) 評(píng)論(4)  編輯 收藏 引用 所屬分類: Pure C/C++
            Comments
            • # re: C++異常捕獲機(jī)制
              小明
              Posted @ 2006-01-09 12:26
              你說:
              因?yàn)閑xceMaker是CDerived的友元函數(shù),可以訪問它的私有成員,故可以上溯到CBase&

              這種說法太牽強(qiáng),我不能理解。

              我認(rèn)為這是vc6/vs2005的C++ exception實(shí)現(xiàn)的一個(gè)Bug。
              你的最后一個(gè)例子 我在C++ BuilderX下面測(cè)試的結(jié)果是:
              caught else
                回復(fù)  更多評(píng)論   
            • # re: C++異常捕獲機(jī)制
              cooelaf
              Posted @ 2006-01-10 08:32
              to 小明:
              我最開始的時(shí)候也是這樣想,因?yàn)樽詈笠环N繼承方式是私有繼承,不是isa關(guān)系,所以不應(yīng)該上溯到CBase,如果如你所說,可能是vs系列的bug,我會(huì)查找一下c++標(biāo)準(zhǔn)對(duì)這方面的說法。謝謝。  回復(fù)  更多評(píng)論   
            • # re: C++異常捕獲機(jī)制
              yskin
              Posted @ 2006-02-22 11:04
              最后一個(gè):
              gcc
              caught else  回復(fù)  更多評(píng)論   
            • # re: C++異常捕獲機(jī)制
              cooelaf
              Posted @ 2006-02-22 16:55
              看來確實(shí)是這樣。  回復(fù)  更多評(píng)論   
             
            亚洲另类欧美综合久久图片区| 久久精品国产亚洲精品2020| 草草久久久无码国产专区| 91精品国产高清久久久久久io| 国产午夜精品理论片久久影视| 国产综合成人久久大片91| 久久精品中文无码资源站| 九九久久自然熟的香蕉图片| 国产成人综合久久久久久 | 99久久亚洲综合精品网站| 久久精品?ⅴ无码中文字幕| 精品久久久无码21p发布 | 狠狠色丁香婷综合久久| 日韩欧美亚洲综合久久影院Ds| 日本人妻丰满熟妇久久久久久| 青青草国产成人久久91网| 久久这里只有精品首页| 青青草国产精品久久| 亚洲国产另类久久久精品黑人 | 久久精品成人一区二区三区| 亚洲国产精品无码久久久蜜芽| 久久青青草原精品影院| 久久久久久亚洲AV无码专区| 色悠久久久久久久综合网 | 亚洲欧美日韩精品久久亚洲区 | 99久久久精品免费观看国产| 久久久国产99久久国产一| 精品久久久久久久中文字幕 | 久久久久亚洲AV综合波多野结衣| 老色鬼久久亚洲AV综合| 久久久www免费人成精品| 性欧美大战久久久久久久| 久久国产精品无码网站| 91久久精品电影| 国内精品久久久久久久coent| av无码久久久久久不卡网站| 伊人久久大香线蕉精品不卡| 精品久久久久国产免费 | 久久久久久久女国产乱让韩| 久久996热精品xxxx| 久久精品国产亚洲精品|