• <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
            大伊人青草狠狠久久| 国产精品热久久毛片| 国产V亚洲V天堂无码久久久| 秋霞久久国产精品电影院| 久久这里只有精品首页| 亚洲狠狠久久综合一区77777| 欧美粉嫩小泬久久久久久久 | 人妻少妇精品久久| 亚洲精品无码成人片久久| 狠狠色丁香婷婷综合久久来来去| 久久久久久久久久久| 久久精品国产亚洲一区二区三区| 色偷偷久久一区二区三区| 欧美日韩精品久久久久| 久久se精品一区精品二区| 狠狠色综合网站久久久久久久高清| 办公室久久精品| 久久91亚洲人成电影网站| 午夜精品久久久久久久| 区久久AAA片69亚洲| 久久中文字幕无码专区| 国产三级精品久久| 日本久久久久久中文字幕| 99久久精品费精品国产一区二区| 久久精品国产免费观看三人同眠| 精品综合久久久久久88小说| 91精品国产色综久久| 久久免费视频网站| 久久国产乱子伦精品免费强| 国产精品久久久久jk制服| 久久婷婷五月综合97色| 久久久女人与动物群交毛片| 久久国产乱子伦免费精品| 精品久久久噜噜噜久久久| 天堂久久天堂AV色综合| 国内精品久久久久影院优| 久久大香香蕉国产| 亚洲综合婷婷久久| 人妻中文久久久久| 亚洲精品美女久久777777| 2020久久精品国产免费|