• <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?;?/span>iterator不含任何成員函數和成員變量,所以繼承不存在額外的開銷。

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

            FeedBack:
            # re: iterator_traits( 轉)
            2008-01-14 05:33 | TheAnswer
            C++中左值的含義是編譯時可知,關注的是對象的地址。  回復  更多評論
              
            久久人人爽人人爽人人片AV不| 亚洲国产成人久久精品动漫| 亚洲欧美成人久久综合中文网| 久久本道综合久久伊人| 亚洲欧美精品一区久久中文字幕| 国内精品久久国产| 久久午夜电影网| 久久婷婷是五月综合色狠狠| 亚洲国产精品18久久久久久| 四虎国产精品免费久久久| 亚洲午夜无码AV毛片久久| jizzjizz国产精品久久| 亚洲人成电影网站久久| 久久久精品一区二区三区| 久久久久亚洲av综合波多野结衣| 久久噜噜电影你懂的| 99蜜桃臀久久久欧美精品网站| 大香网伊人久久综合网2020| 久久精品国产亚洲av麻豆图片 | 日韩乱码人妻无码中文字幕久久| 久久国产一区二区| 亚洲AV日韩精品久久久久久久| 国产AV影片久久久久久| 色综合久久综合中文综合网| 午夜肉伦伦影院久久精品免费看国产一区二区三区 | 久久久久久国产精品美女| 国产精品99久久久久久董美香| 亚洲精品午夜国产VA久久成人 | 青青青青久久精品国产| 久久夜色精品国产噜噜麻豆| 亚洲精品国产字幕久久不卡| 国产精品久久久久久五月尺| 亚洲美日韩Av中文字幕无码久久久妻妇 | 亚洲精品tv久久久久久久久| 久久久久亚洲AV成人网| 国产成人99久久亚洲综合精品| 久久国产精品99精品国产| 人妻少妇久久中文字幕| 久久夜色精品国产网站| 99久久99这里只有免费的精品| 久久久久亚洲AV无码永不|