• <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>

            力為的技術(shù)博客

            聯(lián)系 聚合 管理
              154 Posts :: 1 Stories :: 561 Comments :: 0 Trackbacks

            當(dāng)把子類對(duì)象的指針賦值給父類時(shí),不需要cast。shared_ptr也這樣, 比如:

             

            class A
            {
            public:
            A();
            virtual ~A();
            }
            ;

            class B: public A
            {
            public:
             B();
             
            virtual ~B();
            }
            ;

            typedef shared_ptr
            <A> APtr;
            typdef shared_ptr
            <B> BPtr;

            BPtr pB(
            new B());
            APtr pA 
            = pB;

            這是期望的行為。繼續(xù):

            class C
            {
            public:
              C();
              
            ~C();

              
            const APtr& GetB() const return m_pB; }
            private:
              BPtr m_pB;
            }
            ;


            問題出在哪里?

             

            ---------------------------------------------
            m_pB轉(zhuǎn)換為APtr類型時(shí),產(chǎn)生臨時(shí)對(duì)象。C::GetB()返回的是臨時(shí)對(duì)象的引用。


            一般情況下,沒人會(huì)寫這樣的程序。返回臨時(shí)對(duì)象的引用時(shí)候,編譯器也會(huì)有warning。假如,忽略了warning,就有可能發(fā)生杯具。

            posted on 2011-04-01 18:09 力為 閱讀(2810) 評(píng)論(11)  編輯 收藏 引用 所屬分類: 4. C++ FAQ

            評(píng)論

            # re: 失足于shared_ptr[未登錄] 2011-04-01 21:32 vincent
            加個(gè)const呢?  回復(fù)  更多評(píng)論
              

            # re: 失足于shared_ptr 2011-04-01 21:38 空明流轉(zhuǎn)
            呃。難道你到現(xiàn)在都不曉得咩。。。  回復(fù)  更多評(píng)論
              

            # re: 失足于shared_ptr[未登錄] 2011-04-01 21:48 vincent
            話說加個(gè)const,編譯器會(huì)做處理嗎?  回復(fù)  更多評(píng)論
              

            # re: 失足于shared_ptr 2011-04-01 22:11 yiphon
            為何會(huì)返回臨時(shí)對(duì)象? 不是返回m_pB的引用嗎?
              回復(fù)  更多評(píng)論
              

            # re: 失足于shared_ptr 2011-04-02 09:53 溪流
            返回的不是臨時(shí)對(duì)象的引用。
            之所以 warining,是因?yàn)?m_pB 會(huì)隨著 C 對(duì)象的析構(gòu)而消亡,此時(shí),之前有這個(gè)返回的引用就成了孤魂野鬼了。m_pB 在類外的地位就是一個(gè)局部變量。  回復(fù)  更多評(píng)論
              

            # re: 失足于shared_ptr[未登錄] 2011-04-02 11:35 vincent
            贊一個(gè)= =昨天沒仔細(xì)看題意。。我又2了。。
            返回了m_pB做類型轉(zhuǎn)換的時(shí)候產(chǎn)生的臨時(shí)變量的ref,就像ls所說,孤魂野鬼,這并不是調(diào)用者對(duì)這個(gè)函數(shù)的期望
              回復(fù)  更多評(píng)論
              

            # re: 失足于shared_ptr 2011-04-02 11:42 空明流轉(zhuǎn)
            還好,這個(gè)一般也會(huì)獲得返回值優(yōu)化的。
            一般牽涉到類型轉(zhuǎn)換,返回的時(shí)候都要小心。  回復(fù)  更多評(píng)論
              

            # re: 失足于shared_ptr 2011-04-02 14:21 力為
            補(bǔ)上正確的寫法:

            class C
            {
            public:
            C();
            ~C();

            const BPtr& GetB() const { return m_pB; }
            private:
            BPtr m_pB;
            };
              回復(fù)  更多評(píng)論
              

            # re: 失足于shared_ptr 2011-04-10 00:03 flyinghearts
            @力為
            雖然 B與A存在繼承關(guān)系,但BPtr與APtr可不存在這層關(guān)系,要返回APtr的引用,就必須要先創(chuàng)建一個(gè)APtr對(duì)像。

            APtr pA = pB;
            寫成 APtr pA = static_pointer_cast<A>(pB);
            比較好吧。
              回復(fù)  更多評(píng)論
              

            # re: 失足于shared_ptr 2011-04-11 09:27 力為
            @flyinghearts
            我想shared_ptr隱式轉(zhuǎn)換的行為在于與pure ptr保持一致。
            所以盡管,BPtr與APtr不存在繼承關(guān)系,仍然可以有APtr pA = pB;
            上面的錯(cuò)誤確實(shí)是由于隱式轉(zhuǎn)換產(chǎn)生的臨時(shí)對(duì)象引起的。即使成 APtr pA = static_pointer_cast<A>(pB); ,仍然有臨時(shí)對(duì)象產(chǎn)生。  回復(fù)  更多評(píng)論
              

            # re: 失足于shared_ptr 2011-04-13 23:22 flyinghearts
            @力為

            因?yàn)锽Ptr與APtr不存在繼承關(guān)系,二者間的轉(zhuǎn)換一定會(huì)產(chǎn)生臨時(shí)對(duì)象。
            寫成 APtr pA = static_pointer_cast<A>(pB);
            顯示轉(zhuǎn)換對(duì)象,是給自己提個(gè)醒,也方便以后維護(hù)代碼。

              回復(fù)  更多評(píng)論
              

            久久久久久国产精品无码超碰| 一本一道久久综合狠狠老| 日韩久久久久中文字幕人妻 | 久久精品天天中文字幕人妻| 无码国内精品久久综合88| 久久婷婷五月综合97色| 久久免费线看线看| 久久99精品免费一区二区 | 国产成人综合久久综合| 久久成人18免费网站| 亚洲精品成人网久久久久久| 久久99国产精品一区二区| 亚洲精品国产综合久久一线| 久久婷婷五月综合色奶水99啪| 久久av高潮av无码av喷吹| 一级a性色生活片久久无少妇一级婬片免费放 | 亚洲精品蜜桃久久久久久| 精品久久久久一区二区三区 | 精品国产乱码久久久久久人妻| 久久精品国产第一区二区三区 | 2021少妇久久久久久久久久| 久久丝袜精品中文字幕| 99久久精品免费| 国内精品久久久久久99蜜桃 | 久久久久久毛片免费看| 久久99国产精品一区二区| 伊人色综合久久天天网| 人妻少妇久久中文字幕一区二区 | 久久精品国产欧美日韩| 亚洲国产精品无码久久久秋霞2| 国产精品日韩欧美久久综合| 国产精品免费看久久久| 久久乐国产综合亚洲精品| 人妻系列无码专区久久五月天| 99久久人妻无码精品系列| 久久久久久亚洲AV无码专区| 精品无码久久久久国产动漫3d| 日本加勒比久久精品| 久久这里有精品视频| 色综合合久久天天给综看| 亚洲日本va午夜中文字幕久久|