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

            FeedBack:
            # re: iterator_traits( 轉)
            2008-01-14 05:33 | TheAnswer
            C++中左值的含義是編譯時可知,關注的是對象的地址。  回復  更多評論
              
            久久人人爽人人爽人人片AV麻豆| 久久91精品国产91久| 伊人久久大香线蕉av不卡| 久久亚洲精品成人无码网站| 亚洲狠狠婷婷综合久久蜜芽| 99久久精品免费看国产一区二区三区| 99久久夜色精品国产网站| 国产欧美久久一区二区| 欧美精品丝袜久久久中文字幕 | 99久久免费国产精品| 99久久国产亚洲综合精品| 91精品国产综合久久婷婷| 久久精品视频91| 久久精品国产福利国产秒| 狠狠色丁香久久婷婷综合图片| 精品国产乱码久久久久久1区2区| 久久亚洲国产精品123区| 久久国产乱子精品免费女| 18禁黄久久久AAA片| 久久天天躁狠狠躁夜夜2020老熟妇| 伊人久久无码中文字幕| 久久婷婷五月综合成人D啪| 99久久精品影院老鸭窝| 99久久国产亚洲综合精品| 欧美麻豆久久久久久中文| 国产99久久九九精品无码| 青青草原1769久久免费播放| 久久久久人妻精品一区二区三区| 狠狠综合久久综合88亚洲| 久久久久久久久久久精品尤物| 久久亚洲国产成人影院网站| 精品久久久久久无码中文字幕 | 亚洲AV日韩精品久久久久久久| 欧美一级久久久久久久大| 狠狠色综合久久久久尤物| 国产激情久久久久影院老熟女| 狠狠色丁香久久综合五月| 99国产欧美久久久精品蜜芽| 久久er国产精品免费观看2| 国产精品久久网| 97久久精品人人澡人人爽|