• <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 - 18,  comments - 104,  trackbacks - 0

            相信 xxx_cast 系列都很熟了。

            static_cast, dynamic_cast, const_cast, reinterpret_cast.

            但是當面對boost::shared_ptr的時候呢?

            reinterpret_cast 可以轉換任何類型,這個在討論范圍之外。

            對于下面的這個定義:

             1 class A
             2 {
             3 public:
             4     virtual ~A() {}
             5 };
             6 
             7 class B
             8     : public A
             9 {
            10 public:
            11     ~B() {}
            12 };

            如果用boost::shared_ptr包裝的話:

            1 typedef boost::shared_ptr<A> APtr;
            2 typedef boost::shared_ptr<B> BPtr;

            想想通常對指針的使用:
            1 *pA = new B();
            2 *pB = dynamic_cast<B*>(pA);
            3 // unsafe
            4 *upB = static_cast<B*>(pA);
            5 
            6 pA->;
            7 pB->;
            8 // may crash
            9 upB->;

            如果使用boost::shared_ptr呢。
            1 APtr pA = APtr(new B());    // OK
            2 BPtr pB = pA;               // compile error

            從根本上講,APtr 和 BPtr除了里面包裝的原生指針有點關系以外,他們就是完全不同的兩個類型,當然A和B也是完全不同的類型呀,可是想想看其實B是知道A的存在的??墒荁Ptr完全不知道APtr的存在。那這兒cast怎么進行呢?別說向下轉型了,向上轉型都成問題。

            看看這段代碼:

            1 template <class T>
            2 class shared_ptr
            3 {
            4     template <class F>
            5     shared_ptr(const shared_ptr<F>& p)
            6         : _p(p._p)
            7         , _np(p._np)
            8     {}
            9  private:
            10    T* _p;
            11    reference_counter _np;
            12 };

            這個構造函數可以搞定自動向上轉型,因為編譯器可以自動檢查 _p(p._p) 的合法性。那向下轉型怎么辦呢?看了上面這段代碼,相信很容易解決想想啊轉型的問題了。 只要把  _p(p._p)  改成 _p(dynamic_cast<T*>(p._p) 就可以了,當然要檢查指針的合法性,我就不多寫了。
            當然boost::shared_ptr的作者已經想到這個問題,他給提供了解決方案:


             1 template<class T, class U> 
             2 shared_ptr<T> static_pointer_cast(shared_ptr<U> const & r)
             3 {
             4     return shared_ptr<T>(r, boost::detail::static_cast_tag());
             5 }
             6 
             7 template<class T, class U> 
             8 shared_ptr<T> dynamic_pointer_cast(shared_ptr<U> const & r)
             9 {
            10     return shared_ptr<T>(r, boost::detail::dynamic_cast_tag());
            11 }

            需要用static_cast 轉換普通指針的地方,用shared_static_cast 轉換shared_ptr,
            需要用dynamic_cast 轉換普通指針的地方,用shared_dynamic_cast 轉換shared_ptr.

            前面說過,沒有const的shared_ptr,但是有


            1 const A* pA = new B();
            2 shared_ptr<const A> cpA(pA);         //const
            3 APtr spA = const_pointer_cast<A>(cpA);

            總結一下:
            const_cast               const_pointer_cast
            static_cast              static_pointer_cast
            dynamic_cast             dynamic_pointer_cast

            最后一個小問題:以前,boost中的shared_ptr的cast函數的名字是:shared_xxxx_cast,
            后來,為了IDE自動提供幫助,改成了xxxx_pointer_cast。由此可見,設計庫還是要用戶至上。

            posted on 2009-04-30 21:43 尹東斐 閱讀(5215) 評論(2)  編輯 收藏 引用

            FeedBack:
            # re: boost::shared_ptr 的 cast
            2009-05-01 19:22 | 陳梓瀚(vczh)
            引用計數要變的話也可以const,因為shared_ptr存的是引用計數的指針,而不只是引用計數。  回復  更多評論
              
            # re: boost::shared_ptr 的 cast
            2009-05-01 23:25 | 尹東斐
            @陳梓瀚(vczh)

            嗯,謝謝提醒,我理解有問題。  回復  更多評論
              
            <2009年3月>
            22232425262728
            1234567
            891011121314
            15161718192021
            22232425262728
            2930311234

            常用鏈接

            留言簿(4)

            隨筆檔案

            文章分類

            文章檔案

            相冊

            好友博客

            搜索

            •  

            最新評論

            閱讀排行榜

            評論排行榜

            99re这里只有精品热久久| 思思久久99热免费精品6| 久久99久久99精品免视看动漫| 性做久久久久久久久久久| 精品久久久久久久国产潘金莲| 亚洲伊人久久大香线蕉综合图片| 久久精品蜜芽亚洲国产AV| 国产成人久久久精品二区三区| 色播久久人人爽人人爽人人片aV| 亚洲中文字幕无码久久2020| 国内精品久久久久久久亚洲| 伊人久久大香线蕉综合Av| 伊人色综合久久| 久久精品国产亚洲精品2020 | 久久久久久国产a免费观看黄色大片 | 久久狠狠高潮亚洲精品| 久久人人爽人爽人人爽av| 欧美熟妇另类久久久久久不卡| 久久99精品久久久久久齐齐| 国内精品久久人妻互换| 国产精品久久新婚兰兰| 精品一久久香蕉国产线看播放| 亚洲国产美女精品久久久久∴| 久久综合狠狠综合久久97色| 亚洲国产成人久久精品动漫| 国产美女久久精品香蕉69| 伊人色综合久久天天人手人婷| 欧美日韩成人精品久久久免费看| 婷婷综合久久狠狠色99h| 婷婷综合久久中文字幕蜜桃三电影 | 94久久国产乱子伦精品免费| 久久66热人妻偷产精品9| 久久AV无码精品人妻糸列| 国产免费久久精品99re丫y| 久久久久噜噜噜亚洲熟女综合| 国产精品99久久久久久宅男| 精品久久一区二区三区| 一本大道加勒比久久综合| 欧美精品一区二区精品久久| 99久久伊人精品综合观看| 久久电影网2021|