• <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>

            那誰的技術(shù)博客

            感興趣領(lǐng)域:高性能服務(wù)器編程,存儲(chǔ),算法,Linux內(nèi)核
            隨筆 - 210, 文章 - 0, 評(píng)論 - 1183, 引用 - 0
            數(shù)據(jù)加載中……

            Modern C++ Design(MCD)學(xué)習(xí)筆記 && 測(cè)試代碼(二)

            /* *******************************************************************
            ????created:????2007/02/04
            ????filename:?????CanConverse.cpp
            ????author:????????Lichuang
            ????????????????
            ????????????????VC7,GCC下均可以編譯通過
            ********************************************************************
            */

            #include?
            < iostream >

            using ? namespace ?std;

            template?
            < class ?T,? class ?U >
            class ?Conversion
            {
            private :
            ????
            // ?sizeof(char)?==?1,這是標(biāo)準(zhǔn)規(guī)定的
            ????typedef? char ?Small;
            ????
            // ?sizeof(Big)?==?2?*?sizeof(char)?>?sizeof(char)
            ???? class ?Big???? {? char ?dummy[ 2 ];?} ;
            ????
            // ?Test型別是U,返回值是Small
            ???? static ?Small?Test(U);
            ????
            // ?Test型別是任意型別,返回值是Big
            ???? static ?Big?Test();
            ????
            // ?返回一個(gè)T型別的值
            ???? static ?T?MakeT();

            public :

            ????
            // ?exists的值反映了T是否可以轉(zhuǎn)換為U
            ????
            // ?MakeT首先返回一個(gè)T型別的值,?傳入Test()中
            ????
            // ?如果編譯器確定T可以轉(zhuǎn)換為U,那么調(diào)用返回Small的Test函數(shù)
            ????
            // ?否則調(diào)用返回Big的Test函數(shù),則sizeof(Big)?!=?sizeof(Small)
            ????
            // ?對(duì)于一般的型別如int,?char,double,float而言只是進(jìn)行隱性的轉(zhuǎn)換
            ????
            // ?但是對(duì)于傳入類指針的情況而言,那么派生類的指針可以轉(zhuǎn)換為基類的指針
            ????
            // ?也正是基于這一點(diǎn)可以作為檢查兩個(gè)類是否有繼承關(guān)系的技巧
            ???? enum ?
            ????
            {
            ????????exists?
            = ? sizeof (Test(MakeT()))? == ? sizeof (Small)
            ????}
            ;

            ????
            // ?型別T,U是否可以雙向轉(zhuǎn)換
            ???? enum
            ????
            {
            ????????exists2Way?
            = ?exists? && ?Conversion < U,?T > ::exists
            ????}
            ;

            ????
            // ?是否是同一個(gè)型別
            ???? enum
            ????
            {
            ????????sameType?
            = ? false
            ????}
            ;
            }
            ;

            // ?針對(duì)同一個(gè)型別的模版偏特化類
            template? < class ?T >
            class ?Conversion < T,?T >
            {
            public :
            ????
            enum
            ????
            {
            ????????exists?
            = ? 1 ,
            ????????exists2Way?
            = ? 1 ,
            ????????sameType?
            = ? 1
            ????}
            ;
            }
            ;

            // ?檢查U是否是T的派生類的宏
            // ?第一條語句檢查是否存在U*向T*的轉(zhuǎn)換,如果存在上述關(guān)系那么派生類指針U*可以轉(zhuǎn)換為基類指針T*
            // ?第二條檢測(cè)派生類指針是不是和void*是一個(gè)型別的
            #define ?SUPERSUBCLASS(T,?U)????\
            ????(Conversion
            < const ?U * ,? const ?T *> ::exists? && ????\
            ????
            ! Conversion < const ?T * ,? const ? void *> ::sameType)

            class ?Base
            {
            }
            ;

            class ?Derive
            ????:?
            public ?Base
            {
            }
            ;

            class ?Test
            {
            }
            ;

            int ?main()
            {
            ????cout?
            << ?Conversion < double ,? int > ::exists? << ? ' ? ' ? << ?endl;

            ????
            if ?(SUPERSUBCLASS(Base,?Derive))
            ????
            {
            ????????cout?
            << ? " can?derive\n " ;
            ????}

            ????
            if ?( ! SUPERSUBCLASS(Base,?Test))
            ????
            {
            ????????cout?
            << ? " Can?not?derive\n " ;
            ????}


            ????
            return ? 0 ;
            }


            說明的注釋都在sample代碼里面了,我想無需做太多的解釋,直接看代碼就好了。

            posted on 2007-02-04 23:18 那誰 閱讀(1981) 評(píng)論(5)  編輯 收藏 引用 所屬分類: C\C++

            評(píng)論

            # re: Modern C++ Design(MCD)學(xué)習(xí)筆記 && 測(cè)試代碼(二)  回復(fù)  更多評(píng)論   

            加油,我以看完了。不好搞明白的東西。多寫代碼,即使是把它的代碼一個(gè)一個(gè)
            的重復(fù)的寫一邊和編譯一邊也是非常有意的。

            推薦看看 c++ template 中文版(要是能看懂英文當(dāng)然更是號(hào))。這本書對(duì)模板技術(shù)的表達(dá)的還是非常全面的。

            boost中的MPL庫(kù)是用來完成編譯器編程的,非常的不錯(cuò),有空可以研究一下那個(gè)里面的代碼。boost的基礎(chǔ)就是模板。

            stl并不是單純的用了模板技術(shù),而是用那個(gè)技術(shù)實(shí)現(xiàn)了范型,個(gè)人覺得用模板技術(shù)和范型思想,完全是對(duì)傳統(tǒng)的面向?qū)ο蠹夹g(shù)的顛覆。非常的時(shí)尚
            2007-02-04 23:49 | walkspeed

            # re: Modern C++ Design(MCD)學(xué)習(xí)筆記 && 測(cè)試代碼(二)  回復(fù)  更多評(píng)論   

            簡(jiǎn)單來說,boost的MPL有很多實(shí)際上是用來解決編譯期的運(yùn)算能力的限制問題。也就是說,tips和tricks影響了boost.MPL的可理解性。而且boost.MPL本身就是為了輔助模版程序的開發(fā)而存在的,所以如果沒什么必要,可以不深究。loki和stl相對(duì)簡(jiǎn)單,對(duì)模版能力運(yùn)用的側(cè)重點(diǎn)上又有所不同,可以好好的看看。(個(gè)人以為,模版不全是為了泛型,元編程才是模版的真正意義所在。至于泛型,只是說在C++上用模版來實(shí)現(xiàn)的而已。)

            在C++0x提供了Concept以后,boost的MPL應(yīng)該會(huì)簡(jiǎn)化很多的。

            還有就是模版不是拿來顛覆面向?qū)ο蟮摹K兔嫦驅(qū)ο蠡旧蠜]有什么交叉和沖突,應(yīng)該算得是一個(gè)很有力的補(bǔ)充。
            2007-02-05 14:00 | 空明流轉(zhuǎn)

            # re: Modern C++ Design(MCD)學(xué)習(xí)筆記 && 測(cè)試代碼(二)[未登錄]  回復(fù)  更多評(píng)論   

            看來回貼的兄弟研究過boost眾的mpl了。對(duì)范型很有些了解也。

            我對(duì)范型中的concept概念十分的感興趣。這個(gè)東西對(duì)解耦十分棒,而且對(duì)設(shè)計(jì)思維的擴(kuò)展真是不錯(cuò)。
            2007-02-05 21:18 | walkspeed

            # re: Modern C++ Design(MCD)學(xué)習(xí)筆記 && 測(cè)試代碼(二)  回復(fù)  更多評(píng)論   

            喜歡這個(gè)blog, 加油
            2007-02-05 22:16 | xbluewing

            # re: Modern C++ Design(MCD)學(xué)習(xí)筆記 && 測(cè)試代碼(二)  回復(fù)  更多評(píng)論   

            個(gè)人認(rèn)為,boost.MPL是專門for Metaprogramming的,MPL=MetaProgramming Library嘛,而不是為了Template開發(fā)的。C++的Metaprogramming一定要用Template實(shí)現(xiàn),但Template不一定就要用于Metaprogramming,如STL就不能算Metaprogramming,至少其中大部分不能算。
            《Modern C++ Design》是一本好書,樓主看完后,如果對(duì)Metaprogramming感興趣的話,可以再去看《C++ Template Metaprogramming》,肯定會(huì)大開眼界。只是Metaprogramming對(duì)于大多數(shù)程序員來說,并不是必修課,看你自己的興趣了。
            2007-02-10 10:13 | alai04
            国产精品熟女福利久久AV| 久久国产精品成人片免费| 91视频国产91久久久| 东方aⅴ免费观看久久av| 久久久久国产视频电影| 日韩一区二区久久久久久| 久久99国产综合精品| 亚洲日韩中文无码久久| 久久精品青青草原伊人| 一级做a爰片久久毛片毛片| 青春久久| 色综合合久久天天给综看| 久久性精品| 亚洲国产日韩欧美久久| 亚洲伊人久久成综合人影院| 亚洲国产高清精品线久久 | 久久无码国产| 久久免费国产精品| 久久久久久毛片免费看| 久久精品免费网站网| 午夜精品久久久久久影视777| 香蕉99久久国产综合精品宅男自 | 人妻无码αv中文字幕久久琪琪布 人妻无码精品久久亚瑟影视 | 国产精品久久久久…| 久久伊人精品青青草原高清| 97久久精品人人澡人人爽| 久久久久久久久久久免费精品| 欧美一级久久久久久久大片| 日本五月天婷久久网站| 无码国产69精品久久久久网站| 久久ww精品w免费人成| 办公室久久精品| 一本久久综合亚洲鲁鲁五月天| 久久亚洲AV无码精品色午夜麻豆| 久久妇女高潮几次MBA| 99久久免费国产特黄| 久久www免费人成看国产片| 久久人人爽人人人人爽AV| 精品久久久久中文字幕日本| 国产精品无码久久四虎| 免费无码国产欧美久久18|