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

            woaidongmao

            文章均收錄自他人博客,但不喜標題前加-[轉貼],因其丑陋,見諒!~
            隨筆 - 1469, 文章 - 0, 評論 - 661, 引用 - 0
            數據加載中……

            C++ Traits

            今天看"modern c++ design"的時候發現自己竟然又把以前好不容易弄懂的Traits技術給忘記了,真是...又重新學習了一下,趕緊記下來。
            Traits
            技術可以用來獲得一個 類型 的相關信息的。 首先假如有以下一個泛型的迭代器類,其中類型參數 T 為迭代器所指向的類型:

            template
            <typename T>
            class myIterator
            {
            ...
            };

            當我們使用myIterator時,怎樣才能獲知它所指向的元素的類型呢?我們可以為這個類加入一個內嵌類型,像這樣:
            template <typename T>
            class myIterator
            {
                  typedef T value_type;
            ...
            };
            這樣當我們使用myIterator類型時,可以通過 myIterator::value_type來獲得相應的myIterator所指向的類型。

            現在我們來設計一個算法,使用這個信息。
            template <typename T>
            typename
            myIterator<T>::value_type Foo(myIterator<T> i)
            {
            ...
            }
            這里我們定義了一個函數Foo,它的返回為為 參數i 所指向的類型,也就是T,那么我們為什么還要興師動眾的使用那個value_type呢? 那是因為,當我們希望修改Foo函數,使它能夠適應所有類型的迭代器時,我們可以這樣寫:
            template <typename I> //
            這里的I可以是任意類型的迭代器
            typename I::value_type Foo(I i)
            {
            ...
            }
            現在,任意定義了 value_type內嵌類型的迭代器都可以做為Foo的參數了,并且Foo的返回值的類型將與相應迭代器所指的元素的類型一致。至此一切問題似乎都已解決,我們并沒有使用任何特殊的技術。然而當考慮到以下情況時,新的問題便顯現出來了:

            原生指針也完全可以做為迭代器來使用,然而我們顯然沒有辦法為原生指針添加一個value_type的內嵌類型,如此一來我們的Foo()函數就不能適用原生指針了,這不能不說是一大缺憾。那么有什么辦法可以解決這個問題呢? 此時便是我們的主角:類型信息榨取機 Traits 登場的時候了

            ....drum roll......

            我們可以不直接使用myIteratorvalue_type,而是通過另一個類來把這個信息提取出來:
            template <typename T>
            class Traits
            {
                  typedef typename T::value_type value_type;
            };
            這樣,我們可以通過 Traits<myIterator>::value_type 來獲得myIteratorvalue_type,于是我們把Foo函數改寫成:
            template <typename I> //
            這里的I可以是任意類型的迭代器
            typename Traits<I>::value_type Foo(I i)
            {
            ...
            }
            然而,即使這樣,那個原生指針的問題仍然沒有解決,因為Trait類一樣沒辦法獲得原生指針的相關信息。于是我們祭出C++的又一件利器--偏特化(partial specialization)
            template <typename T>
            class Traits<T*> //
            注意 這里針對原生指針進行了偏特化
            {
                  typedef typename T value_type;
            };
            通過上面這個 Traits的偏特化版本,我們陳述了這樣一個事實:一個 T* 類型的指針所指向的元素的類型為 T

            如此一來,我們的 Foo函數就完全可以適用于原生指針了。比如:
            int * p;
            ....
            int i = Foo(p);
            Traits
            會自動推導出 p 所指元素的類型為 int,從而Foo正確返回。


            ............ 終于寫完了,開始寫的時候沒想到會寫那么長,暈......

             

            posted on 2008-11-08 22:53 肥仔 閱讀(336) 評論(0)  編輯 收藏 引用 所屬分類: C++ 模板

            韩国免费A级毛片久久| 久久亚洲精品无码aⅴ大香| 精品久久久久香蕉网| 久久久久久狠狠丁香| 午夜肉伦伦影院久久精品免费看国产一区二区三区 | 欧美精品丝袜久久久中文字幕 | 国产欧美久久一区二区| 99久久伊人精品综合观看| 97久久国产露脸精品国产| 国产无套内射久久久国产| 伊人久久大香线蕉综合Av| 99久久婷婷国产综合精品草原 | 久久亚洲国产精品123区| 久久久久亚洲AV无码麻豆| 日韩久久无码免费毛片软件| 国产精品久久午夜夜伦鲁鲁| 久久久久亚洲AV成人网人人网站| 国产99久久九九精品无码| 人妻无码αv中文字幕久久琪琪布| 久久久久国产亚洲AV麻豆| 香港aa三级久久三级| 久久婷婷五月综合97色| 久久精品一本到99热免费| 日日狠狠久久偷偷色综合0| 国产日韩久久免费影院| 日韩一区二区久久久久久| 99久久精品国内| 成人国内精品久久久久一区| 精品多毛少妇人妻AV免费久久| 久久久精品国产亚洲成人满18免费网站 | 久久亚洲国产精品一区二区| 中文字幕久久精品无码| 亚洲AV无码久久精品狠狠爱浪潮| 精品综合久久久久久98| 精品久久人人爽天天玩人人妻| 久久久久国产精品嫩草影院| 久久99九九国产免费看小说| 久久久久久伊人高潮影院| 少妇高潮惨叫久久久久久| 国内精品伊人久久久久av一坑| 久久99精品国产99久久|