• <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++中左值的含義是編譯時可知,關注的是對象的地址。  回復  更多評論
              
            久久国产精品波多野结衣AV| 久久久久亚洲AV片无码下载蜜桃| 久久无码人妻一区二区三区| 亚洲国产成人久久笫一页| 国产高潮久久免费观看| 久久久久久免费一区二区三区| 久久久久亚洲Av无码专| 无码人妻久久一区二区三区| 精品人妻伦九区久久AAA片69| 久久精品国产亚洲AV香蕉| 波多野结衣久久一区二区| AV无码久久久久不卡蜜桃| 中文精品久久久久人妻不卡| 久久久av波多野一区二区| 久久精品国产清高在天天线| 久久久精品午夜免费不卡| 久久国产成人精品国产成人亚洲| 久久精品免费大片国产大片| 亚洲精品tv久久久久久久久久| 久久99久国产麻精品66| 久久久国产乱子伦精品作者| 91精品国产91久久| 久久夜色撩人精品国产| 久久亚洲熟女cc98cm| 久久久久久久人妻无码中文字幕爆| 国内精品久久九九国产精品| 久久久久久国产a免费观看不卡 | 狠狠综合久久综合88亚洲| 午夜精品久久久久久久| 日本三级久久网| 久久久久久久久久久久久久| 久久久九九有精品国产| 四虎影视久久久免费观看| 亚洲αv久久久噜噜噜噜噜| 狠狠干狠狠久久| 久久久久久久久久久久久久 | A级毛片无码久久精品免费| 亚洲国产成人精品91久久久 | 久久免费视频观看| 欧美亚洲国产精品久久| 日韩精品国产自在久久现线拍|