• <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í)筆記 && 測試代碼(二)

            /* *******************************************************************
            ????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)
            ????
            // ?對于一般的型別如int,?char,double,float而言只是進(jìn)行隱性的轉(zhuǎn)換
            ????
            // ?但是對于傳入類指針的情況而言,那么派生類的指針可以轉(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
            ????}
            ;
            }
            ;

            // ?針對同一個(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*
            // ?第二條檢測派生類指針是不是和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 那誰 閱讀(1988) 評(píng)論(5)  編輯 收藏 引用 所屬分類: C\C++

            評(píng)論

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

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

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

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

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

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

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

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

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

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

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

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

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

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

            # re: Modern C++ Design(MCD)學(xué)習(xí)筆記 && 測試代碼(二)  回復(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》是一本好書,樓主看完后,如果對Metaprogramming感興趣的話,可以再去看《C++ Template Metaprogramming》,肯定會(huì)大開眼界。只是Metaprogramming對于大多數(shù)程序員來說,并不是必修課,看你自己的興趣了。
            2007-02-10 10:13 | alai04
            伊人久久大香线蕉精品| 人人狠狠综合久久亚洲| 国内精品伊人久久久久| 久久精品无码免费不卡| 久久久亚洲裙底偷窥综合| 久久国产精品一国产精品金尊| 久久99国产精一区二区三区| 亚洲精品无码久久不卡| 91精品国产色综合久久| 久久亚洲精品无码AV红樱桃| 久久国产精品-久久精品| 久久天天躁狠狠躁夜夜2020一| 国产精品久久久久无码av| 久久久久综合中文字幕| 国产精品久久久久久久久鸭| 亚洲国产精品无码久久久久久曰| 俺来也俺去啦久久综合网| 狠狠色婷婷久久综合频道日韩 | 2020国产成人久久精品| 久久久国产精品网站| 久久丫精品国产亚洲av不卡 | 久久精品国产AV一区二区三区| 91久久精品无码一区二区毛片| 色欲综合久久中文字幕网| 亚洲午夜无码久久久久小说| 久久久久免费视频| 99久久精品免费观看国产| 久久九九青青国产精品| 久久97精品久久久久久久不卡| 无码人妻精品一区二区三区久久久| 区亚洲欧美一级久久精品亚洲精品成人网久久久久 | 影音先锋女人AV鲁色资源网久久| 最新久久免费视频| 精品久久久一二三区| 久久只有这精品99| 久久婷婷人人澡人人爽人人爱| 久久天天婷婷五月俺也去| 18禁黄久久久AAA片| 人人狠狠综合久久88成人| 久久99亚洲网美利坚合众国| 久久精品夜夜夜夜夜久久|