• <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)題 就是在寫(xiě)程序的時(shí)候要暴露對(duì)象的類(lèi)型
            就像這個(gè)樣子 :
            template<typename T>
            vector<T>::iterator find(const T& )
            {
            ........
            }
            而如果暴露了類(lèi)型的話(huà) 那么就不能寫(xiě)一段代碼而完成問(wèn)題了 必須為每種容器都寫(xiě)出相同的算法
            怎么辦呢 可以在find中傳出兩個(gè)參數(shù)
            template<typename T>
            vector<T>::iterator find(const T&, T& result )
            {
            ........
            }
            但是好像還是有問(wèn)題 譬如類(lèi)型的引用 還有size 指針 等等 都是不同的類(lèi)型 寫(xiě)起來(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è)類(lèi)型支持時(shí)就為他特化一個(gè)類(lèi) 支持這樣的特性
            感覺(jué)這樣寫(xiě)的話(huà) 在特化的時(shí)候會(huì)不會(huì)代碼會(huì)比較多呢 ...
            具體就是
            template<typename T>
            class something
            {
            // 在這里寫(xiě)對(duì)廣大的類(lèi)的操作
            }

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

            而為了type traits來(lái)說(shuō) 它的特殊操作就是在泛型類(lèi)里面做一個(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不然就用自己寫(xiě)的 呵呵
            posted on 2007-11-15 20:43 DraculaW 閱讀(935) 評(píng)論(0)  編輯 收藏 引用

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


            久久久久久曰本AV免费免费| 婷婷国产天堂久久综合五月| 久久人人爽人人澡人人高潮AV| 2020久久精品国产免费| 久久这里只精品国产99热| 狠狠色伊人久久精品综合网 | 人妻久久久一区二区三区| 成人妇女免费播放久久久 | 久久精品国产清自在天天线| 色播久久人人爽人人爽人人片aV | 久久久久久久久无码精品亚洲日韩 | 久久无码国产| 久久久久AV综合网成人| 国产精品内射久久久久欢欢| 久久午夜羞羞影院免费观看| 国产精品青草久久久久福利99 | 狠狠色综合网站久久久久久久| 久久无码专区国产精品发布| 久久国产精品99精品国产987| 久久综合亚洲鲁鲁五月天| 久久国产精品久久精品国产| 久久久久亚洲AV无码麻豆| 久久伊人影视| 国产高潮久久免费观看| 精品国际久久久久999波多野| 午夜视频久久久久一区| 国产精品日韩深夜福利久久| 久久精品亚洲中文字幕无码麻豆| 久久乐国产综合亚洲精品| 国产一区二区精品久久岳| 99久久精品国内| 99久久久精品免费观看国产| 精品国产青草久久久久福利| 噜噜噜色噜噜噜久久| 欧美日韩中文字幕久久久不卡| 国内精品久久久久久久久电影网| 国产精品久久成人影院| 97久久天天综合色天天综合色hd| 久久偷看各类wc女厕嘘嘘| 久久男人Av资源网站无码软件 | 国内精品久久久久久野外|