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

            DraculaW

              C++博客 :: 首頁(yè) :: 新隨筆 :: 聯(lián)系 :: 聚合  :: 管理 ::
              19 隨筆 :: 0 文章 :: 7 評(píng)論 :: 0 Trackbacks
            模板的引入 使c++產(chǎn)生了泛型的算法 泛型的容器
            這兩個(gè)是個(gè)好東西 但是在將兩項(xiàng)技術(shù)結(jié)合的時(shí)候產(chǎn)生了一個(gè)問(wèn)題 就是在寫程序的時(shí)候要暴露對(duì)象的類型
            就像這個(gè)樣子 :
            template<typename T>
            vector<T>::iterator find(const T& )
            {
            ........
            }
            而如果暴露了類型的話 那么就不能寫一段代碼而完成問(wèn)題了 必須為每種容器都寫出相同的算法
            怎么辦呢 可以在find中傳出兩個(gè)參數(shù)
            template<typename T>
            vector<T>::iterator find(const T&, T& result )
            {
            ........
            }
            但是好像還是有問(wèn)題 譬如類型的引用 還有size 指針 等等 都是不同的類型 寫起來(lái)還是很頭大
            于是 聰明的人們想出了type traits這項(xiàng)技術(shù)
            這項(xiàng)技術(shù)
            typename<typename T>
            class iterator
            {
            public:
                typedef T value_type
            }
            typename<typename I>
            typename I::value_type
            find(I &)
            {
            }

            與STL的實(shí)現(xiàn)不同 在boost中 他們使用的是模板片特化來(lái)實(shí)現(xiàn)的type traits
            基本思想就是 默認(rèn)大部分都不支持某種特性 然后 當(dāng)某個(gè)類型支持時(shí)就為他特化一個(gè)類 支持這樣的特性
            感覺(jué)這樣寫的話 在特化的時(shí)候會(huì)不會(huì)代碼會(huì)比較多呢 ...
            具體就是
            template<typename T>
            class something
            {
            // 在這里寫對(duì)廣大的類的操作
            }

            然后對(duì)于特殊的類型 譬如說(shuō) int
            template<>
            class something<int>
            {
            //然后在這里寫對(duì)Int做的特殊的操作
            }

            而為了type traits來(lái)說(shuō) 它的特殊操作就是在泛型類里面做一個(gè)枚舉 值為false而在 int里面這個(gè)值為true
            那么 當(dāng)算法來(lái)用這個(gè)對(duì)象時(shí) 可以根據(jù)這個(gè)枚舉的值來(lái)選擇相應(yīng)的算法 ,譬如對(duì)int的速度比較快的 或者對(duì)泛型的正確的算法

            下面是 std::swap的一個(gè)優(yōu)化版本

            //
            // iter_swap:
            // tests whether iterator is a proxying iterator or not, and
            // uses optimal form accordingly:
            //
            namespace detail{
            template <typename I>
            static void do_swap(I one, I two, const boost::false_type&)
            {
                typedef typename std::iterator_traits<I>::value_type v_t;
                v_t v = *one;
                *one = *two;
                *two = v;
            }
            template <typename I>
            static void do_swap(I one, I two, const boost::true_type&)
            {
                using std::swap;
                swap(*one, *two);
            }
            }

            template <typename I1, typename I2>
            inline void iter_swap(I1 one, I2 two)
            {
                //
                // See is both arguments are non-proxying iterators,
                // and if both iterator the same type:
                //
                typedef typename std::iterator_traits<I1>::reference r1_t;
                typedef typename std::iterator_traits<I2>::reference r2_t;
                typedef boost::integral_constant<bool,
                ::boost::is_reference<r1_t>::value
                    && ::boost::is_reference<r2_t>::value
                    && ::boost::is_same<r1_t, r2_t>::value> truth_type;

                detail::do_swap(one, two, truth_type());
            }

            其中 boost::integral_constant<bool, ::boost::is_reference<r1_t>::value
                    && ::boost::is_reference<r2_t>::value
                    && ::boost::is_same<r1_t, r2_t>::value> truth_type
            就是一個(gè)枚舉 看傳入的參數(shù)是否可以用std::swap 如果可以則連接到std::swap不然就用自己寫的 呵呵
            posted on 2007-11-15 20:43 DraculaW 閱讀(936) 評(píng)論(0)  編輯 收藏 引用

            只有注冊(cè)用戶登錄后才能發(fā)表評(píng)論。
            網(wǎng)站導(dǎo)航: 博客園   IT新聞   BlogJava   博問(wèn)   Chat2DB   管理


            狠狠久久综合| 久久久久无码专区亚洲av| 久久免费的精品国产V∧| 亚洲国产小视频精品久久久三级 | 国内精品久久久久影院老司| 国产精品久久久久a影院| 一本一本久久A久久综合精品 | 亚洲国产成人久久一区WWW| 国产免费久久精品99re丫y| 午夜天堂精品久久久久| 国产日产久久高清欧美一区| 久久激情五月丁香伊人| 久久亚洲精品无码VA大香大香| 久久精品国产99国产精品导航| 99久久国语露脸精品国产| 久久久免费观成人影院| 亚洲AV成人无码久久精品老人| 精品一区二区久久| 久久最新免费视频| 久久99亚洲网美利坚合众国| 久久精品国产亚洲Aⅴ香蕉| 无码人妻久久一区二区三区免费 | 国产99久久九九精品无码| 亚洲精品综合久久| 久久精品国内一区二区三区| 囯产精品久久久久久久久蜜桃| 婷婷久久五月天| 久久精品男人影院| 一本久道久久综合狠狠爱| 国产亚洲精午夜久久久久久| 人妻精品久久久久中文字幕69 | 日本精品久久久久影院日本| 国产午夜精品理论片久久影视 | 婷婷久久精品国产| 久久99国产精一区二区三区| 午夜人妻久久久久久久久| 亚洲v国产v天堂a无码久久| 青青草国产成人久久91网| 无码久久精品国产亚洲Av影片| 亚洲国产成人精品91久久久 | 亚洲国产精品无码久久久秋霞2|