• <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>
            隨筆 - 8  文章 - 26  trackbacks - 0
            <2025年6月>
            25262728293031
            1234567
            891011121314
            15161718192021
            22232425262728
            293012345

            常用鏈接

            留言簿(5)

            隨筆檔案

            文章分類

            文章檔案

            相冊(cè)

            C++語(yǔ)言

            搜索

            •  

            最新評(píng)論

            閱讀排行榜

            評(píng)論排行榜

            轉(zhuǎn)載自:http://dev.csdn.net/article/3/3354.shtm
             

            /*******************************************************************************
             *  SGI*STL是STL之父Alexander Stepanov和STL巨匠Matt Austern等人的作品, 是當(dāng)今  *
             *  最富盛名、最出色的STL實(shí)現(xiàn)版本,全部源代碼和說(shuō)明文檔可從www.sgi.com/STL/下  *
             *  載, 是我們學(xué)習(xí)STL的最佳范本. 但是眾所周知, STL使用了大量復(fù)雜艱深的C++特性, *
             *  加上STL本身的復(fù)雜和龐大, 使得閱讀代碼本身就成為一件非常困難的工作. 以下文  *
             *  字是我在學(xué)習(xí)STL過(guò)程中得到的一些經(jīng)驗(yàn)和猜測(cè), 希望能對(duì)大家有所幫助, 更希望能  *
             *  得到大家的批評(píng)和指正, 以利于我們的共同提高.                                *
             *                                                                      myan   *
             *******************************************************************************/

            在SGI*STL源代碼里, typename這個(gè)新的C++關(guān)鍵字得使用可以說(shuō)是隨處可見(jiàn). 很多以前學(xué)習(xí)過(guò)
            C++的人可能還不認(rèn)識(shí)typename, 其實(shí)它的常規(guī)用法很簡(jiǎn)單: 在聲明模板函數(shù)或者模板類時(shí),
            傳統(tǒng)的寫法:
            template <class T>
            generic_function() {
            //........
            }

            亦可以寫成
            template <typename T>
                     ------------
            generic_func() {
            //...............
            }
            引入這個(gè)關(guān)鍵字主要是為了避免class可能給人帶來(lái)的混淆.
            本來(lái)typename的用法就是這么簡(jiǎn)單, 但是STL源代碼中還有typename的一種不常見(jiàn)的用法, 如果
            不了解, 閱讀源代碼時(shí)就會(huì)遇到困難. 因?yàn)槟壳拔艺也坏接嘘P(guān)這個(gè)問(wèn)題的說(shuō)明, 所以自己試驗(yàn)了
            一下, 得到一個(gè)猜測(cè), 現(xiàn)簡(jiǎn)介如下, 請(qǐng)有識(shí)之士斧正.

            首先看一段SGI*STL源代碼, 摘自stl_iterator.h

            1: template <class _Container, class _Iterator>
            2: inline insert_iterator<_Container> inserter(_Container& __x, _Iterator __i)
            3: {
            4:   typedef typename _Container::iterator __iter;
            5:   return insert_iterator<_Container>(__x, __iter(__i));
            6:  }

            令人費(fèi)解的部分在第四行. 請(qǐng)大家在看我的解釋之前先想一想, 我不敢保證下面解釋的正確性和
            全面性.

            解釋:
                我認(rèn)為typename的語(yǔ)義是: 通知編譯器, 在typename后面被聲明的東西是一個(gè)類型, 而不是別的
            什么東西.

             

             1例子:
             2// tpname.cpp
             3#include <iostream>
             4#include <typeinfo>  // for typeid() operator
             5
             6using namespace std;
             7
             8template <typename TP>
             9struct COne {   // default member is public
            10    typedef TP one_value_type;
            11}
            ;
            12
            13template <typename COne>   // 用一個(gè)模板類作為模板參數(shù), 這是很常見(jiàn)的
            14struct CTwo {
            15    // 請(qǐng)注意以下兩行
            16    // typedef COne::one_value_type  two_value_type;   // *1
            17    typedef typename COne::one_value_type  two_value_type;      // *2  
            18}
            ;
            19
            20// 以上兩個(gè)模板類只是定義了兩個(gè)內(nèi)部的public類型, 但請(qǐng)注意第二個(gè)類CTwo的two_value_type類型
            21// 依賴COne的one_value_type, 而后者又取決于COne模板類實(shí)例化時(shí)傳入的參數(shù)類型.
            22
            23int main()
            24{
            25    typedef COne<int> OneInt_type;
            26    typedef CTwo< OneInt_type > TwoInt_type;
            27    TwoInt_type::two_value_type i;
            28    int j;
            29    if ( typeid(i) == typeid(j) )   // 如果i是int型變量
            30        cout << "Right!" << endl;   // 打印Right
            31    return;
            32}

            33//  ~tpname.cpp
            34

             

            以上例子在Linux下用G++ 2.91編譯通過(guò), 結(jié)果打印"Right". 但是如果把*1行的注釋號(hào)去掉, 注釋
            *2行, 則編譯時(shí)報(bào)錯(cuò), 編譯器不知道COne::one_value_type為何物. 通常在模板類參數(shù)中的類型到
            實(shí)例化之后才會(huì)顯露真身, 但這個(gè)CTwo類偏偏又要依賴一個(gè)已經(jīng)存在的COne模板類, 希望能夠預(yù)先
            保證CTwo::two_value_type與COne::one_value屬于同一類型, 這是就只好請(qǐng)typename出山, 告訴
            編譯器, 后面的COne::one_value_type是一個(gè)已經(jīng)存在于某處的類型的名字(type name), 這樣編譯
            器就可以順利的工作了.

            posted on 2008-06-24 21:56 楊彬彬 閱讀(220) 評(píng)論(0)  編輯 收藏 引用 所屬分類: C++語(yǔ)言
            国产精品狼人久久久久影院| 久久久久久无码Av成人影院| 国产一级做a爰片久久毛片| 精品久久久久久久无码| 欧美无乱码久久久免费午夜一区二区三区中文字幕 | 一本色道久久88综合日韩精品 | 精品视频久久久久| 国产精品久久新婚兰兰| 久久精品www| 合区精品久久久中文字幕一区| 无码国内精品久久综合88| 久久这里只有精品首页| 久久se精品一区二区| 日本久久中文字幕| 伊人久久免费视频| 国产精品久久永久免费| 99久久国产宗和精品1上映 | 国产aⅴ激情无码久久| 国产女人aaa级久久久级| 午夜精品久久久久久影视riav| 精品国产一区二区三区久久蜜臀| 国产亚洲精品久久久久秋霞| 久久影院久久香蕉国产线看观看| 国产精品成人久久久久三级午夜电影| 久久婷婷色综合一区二区| 久久久久久久亚洲Av无码| 久久亚洲AV无码西西人体| 久久精品国产亚洲麻豆| 九九久久自然熟的香蕉图片| 精品熟女少妇AV免费久久| 久久久久亚洲精品天堂久久久久久 | 久久九九精品99国产精品| 亚洲国产精品一区二区三区久久 | 狠狠久久综合| 狠狠综合久久综合中文88| 国产精品嫩草影院久久| 久久成人永久免费播放| 国产视频久久| 久久亚洲2019中文字幕| 欧美日韩精品久久久久| 久久久久亚洲AV片无码下载蜜桃|