• <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 小果子 閱讀(1933) 評論(1)  編輯 收藏 引用 所屬分類: 學習筆記

            FeedBack:
            # re: iterator_traits( 轉)
            2008-01-14 05:33 | TheAnswer
            C++中左值的含義是編譯時可知,關注的是對象的地址。  回復  更多評論
              
            久久国产精品成人影院| 精品久久久久久久久久中文字幕| 一本久久知道综合久久| 色综合久久88色综合天天| 久久久免费观成人影院 | 国产Av激情久久无码天堂| 国产精品对白刺激久久久| 久久本道综合久久伊人| 亚洲精品乱码久久久久久久久久久久 | 亚洲日本va中文字幕久久| 久久99久久99精品免视看动漫| 国产精品久久久久9999高清| 久久久久亚洲av成人无码电影 | 久久久久久久精品成人热色戒| 99精品久久精品一区二区| 久久久久国产视频电影| 无码日韩人妻精品久久蜜桃 | 99久久无色码中文字幕人妻| 久久91精品国产91久久户| 久久久www免费人成精品| 91精品日韩人妻无码久久不卡| 婷婷综合久久中文字幕蜜桃三电影| 国产高清美女一级a毛片久久w| 少妇久久久久久久久久| 四虎影视久久久免费观看| 亚洲国产精品久久久久网站| 久久精品午夜一区二区福利| 色8激情欧美成人久久综合电| 久久香蕉一级毛片| 国产精品久久网| 人妻无码αv中文字幕久久琪琪布| 一级做a爰片久久毛片看看| 国产亚洲美女精品久久久| 久久亚洲综合色一区二区三区| 无码日韩人妻精品久久蜜桃| 亚洲精品美女久久777777| 中文成人无码精品久久久不卡| 久久综合一区二区无码| 久久精品无码免费不卡| 久久996热精品xxxx| 久久99精品久久久久久齐齐|