• <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>
            xiaoguozi's Blog
            Pay it forword - 我并不覺的自豪,我所嘗試的事情都失敗了······習慣原本生活的人不容易改變,就算現狀很糟,他們也很難改變,在過程中,他們還是放棄了······他們一放棄,大家就都是輸家······讓愛傳出去,很困難,也無法預料,人們需要更細心的觀察別人,要隨時注意才能保護別人,因為他們未必知道自己要什么·····

             

            Reference Type  Pointer Type

            所謂左值(lValue):是用來代表某個對象的一個東西。如果p是指向類型為T的某個對象,那么表達式*p不能只是返回類型為T的對象,而必須是返回一個lValue(左值)。

               平時總是拿起*p就直接賦值(對于簡單基本類型,例如int *p = &I ;  *p=3),沒想什么*p返回左值那么多。但是當在自定義類中重栽*運算符的時候,我們就要特別小心,要注意到這點,返回為T& 才對。

            言規正傳

            iterator_traits的某些機制所蘊涵的意義十分微妙而深遠,不過它的實現卻不是很復雜,不過這些東西看起來比較容易看懂,真正能夠靈活使用就需要花時間領悟了,為什么會采取這種方法解決問題,和其它的方法對比有什么好處和提高?這種明白這些問題才算掌握了trait的實質。

            template< class Iterator>

            struct iterator_traits

            {

            typedef   typename Iterator::iterator_category   iterator_category;

            typedef   typename Iterator::value_type        value_type;

            typedef   typename Iterator::difference_type    difference_type;

            typedef   typename Iterator::pointer           pointer;

            typedef   typename Iterator::reference         reference    ;

            };

            template< class T>

            struct iterator_traits

            {

            typedef   random_access_iterator_tag   iterator_category;

            typedef   T        value_type;

            typedef   ptrdiff_t    difference_type;

            typedef   T*           pointer;

            typedef   T&         reference    ;

            };

            template< class T>

            struct iterator_traits

            {

            typedef   random_access_iterator_tag   iterator_category;

            typedef   T        value_type;

            typedef   ptrdiff_t    difference_type;

            typedef   T*           pointer;

            typedef   T&         reference    ;

            };

            當你定義一個自己的算法,你需要關注這個機制,下面兩個理由就是你可能要用到iterator_traits

                 你必須返回某值,或者是申明臨時變量,而其它型別與iteratorvalue type 或者different type或者reference type 或者pointer type一致。

                 你的算法類似與advance,必須根據iterator的分類來決定不同的實現方法(提高效率,在編譯時候進行判斷而不是在運行的時候進行判斷),沒有traits機制,你只好在‘一般化但是沒效率’或者‘有效率但是過度狹隘’中進行抉擇。

            當定義一個Iterator 類,就得在改類中定義五個嵌套的類型,如上面的五個所示。要不然就得針對你的Iterator類,明白的令iterator_traitsIterator特化,就像iterator_traits要明白的針對指針而特化一樣。第一種做法總是比較簡單,尤其是STL的一個輔助類,base class iterator,讓事情變得更簡單了。

            template< class Category,

            class Value,

            class Distance =ptrdiff_t,

            class Pointer = Value*,

            class Reference = Value &

            >

            struct iterator

            {

            typedef Category iterator_category;

            typedef Value      value_type;

            typedef Distance difference_type;

            typedef Pointer     pointer;

            typedef Reference   reference;

            };

                 為了確保iterator_traits能夠對新的iterator class有適當的定義,最簡單的方法就是從iterator類派生自己的iterator。基類iterator不含任何成員函數和成員變量,所以繼承不存在額外的開銷。

            posted on 2008-01-13 11:34 小果子 閱讀(1934) 評論(1)  編輯 收藏 引用 所屬分類: 學習筆記

            FeedBack:
            # re: iterator_traits( 轉)
            2008-01-14 05:33 | TheAnswer
            C++中左值的含義是編譯時可知,關注的是對象的地址。  回復  更多評論
              
            久久久久亚洲AV无码观看| 久久国产乱子伦精品免费午夜| 国产一久久香蕉国产线看观看| 日产精品久久久久久久性色| 亚洲国产精品无码久久久秋霞2 | 午夜精品久久久久久影视riav| 久久精品一区二区三区不卡| 国产精品岛国久久久久| 国产精品视频久久| 亚洲国产成人久久综合一| 久久93精品国产91久久综合| 亚州日韩精品专区久久久| 久久精品一区二区三区AV| 国内精品久久久久影院优| 超级碰久久免费公开视频| 久久综合亚洲色HEZYO社区| 亚洲乱码中文字幕久久孕妇黑人| 91精品国产91久久久久久青草| 久久福利资源国产精品999| 偷窥少妇久久久久久久久| 久久久久久曰本AV免费免费| 国产精品免费福利久久| 久久久受www免费人成| 久久久亚洲AV波多野结衣| 久久久91精品国产一区二区三区 | 久久精品国产男包| 精品久久久噜噜噜久久久 | 欧美黑人又粗又大久久久| 999久久久免费国产精品播放| 囯产精品久久久久久久久蜜桃 | 中文成人久久久久影院免费观看| 久久99国产乱子伦精品免费| 一本色道久久88综合日韩精品| 久久久久亚洲AV无码麻豆| 亚洲国产成人久久综合一区77| 久久精品亚洲一区二区三区浴池| 久久人人爽人人爽人人片AV麻豆| 99久久无色码中文字幕| 伊人久久大香线蕉AV色婷婷色| 伊人久久大香线蕉AV一区二区| 久久久精品国产亚洲成人满18免费网站 |