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

            那誰(shuí)的技術(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下均可以編譯通過(guò)
            ********************************************************************
            */

            #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的派生類的宏
            // ?第一條語(yǔ)句檢查是否存在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 ;
            }


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

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

            評(píng)論

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

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

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

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

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

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

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

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

            看來(lái)回貼的兄弟研究過(guò)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是專門(mén)for Metaprogramming的,MPL=MetaProgramming Library嘛,而不是為了Template開(kāi)發(fā)的。C++的Metaprogramming一定要用Template實(shí)現(xiàn),但Template不一定就要用于Metaprogramming,如STL就不能算Metaprogramming,至少其中大部分不能算。
            《Modern C++ Design》是一本好書(shū),樓主看完后,如果對(duì)Metaprogramming感興趣的話,可以再去看《C++ Template Metaprogramming》,肯定會(huì)大開(kāi)眼界。只是Metaprogramming對(duì)于大多數(shù)程序員來(lái)說(shuō),并不是必修課,看你自己的興趣了。
            2007-02-10 10:13 | alai04
            久久久久国产精品人妻| 久久久无码精品午夜| 久久99久久99小草精品免视看| 午夜肉伦伦影院久久精品免费看国产一区二区三区 | 久久这里的只有是精品23| 久久精品亚洲日本波多野结衣| 色综合久久久久网| 久久人妻少妇嫩草AV蜜桃| 色综合久久久久网| 欧洲精品久久久av无码电影| 久久成人18免费网站| 久久精品一本到99热免费| 久久久久久久波多野结衣高潮| 日韩一区二区久久久久久| 一本久久a久久精品vr综合| 久久国产乱子伦精品免费午夜| 久久精品亚洲一区二区三区浴池| 亚洲人成电影网站久久| 国产精品无码久久四虎| 国产精品久久久福利| 久久婷婷激情综合色综合俺也去| 欧美麻豆久久久久久中文| 国产精品对白刺激久久久| 亚洲欧美伊人久久综合一区二区| 久久久久九国产精品| 99久久国产综合精品网成人影院| 久久精品毛片免费观看| 色偷偷88888欧美精品久久久| 亚洲国产日韩欧美综合久久| 国产综合免费精品久久久| 久久久久久综合一区中文字幕| 久久久久久国产精品免费无码| 77777亚洲午夜久久多人| 久久影院午夜理论片无码| 久久精品国产只有精品66| 精品久久久久久国产牛牛app| 国产精品一区二区久久精品无码 | 国内精品久久国产| 一级做a爰片久久毛片免费陪| 久久91精品国产91| 亚洲国产精品久久电影欧美|