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

            可冰

            冰,是沉睡著的水......

              C++博客 :: 首頁(yè) :: 新隨筆 :: 聯(lián)系 :: 聚合  :: 管理 ::
              37 隨筆 :: 5 文章 :: 94 評(píng)論 :: 0 Trackbacks
            看了cpunion寫的IDL的代碼,我知道了這樣的用法:
            在模板參數(shù)中,類型參數(shù)可以這樣構(gòu)造:
            ??????? template_class< type( type1, type2, ... ) > a_class;
            比如,可以void( void ), void(), void( int ), 也可以int( void ), string( int )等等,編譯器是將它們當(dāng)作不同的類型的來(lái)處理的.對(duì)此,我寫了一些代碼作了一下測(cè)試(見文末).但我也僅僅是有一個(gè)感性的認(rèn)識(shí)而已,對(duì)于其為什么可以這樣(因?yàn)閺奈匆娔谋緯辖榻B過(guò)這樣的用法),我一點(diǎn)也不知道.
            希望大家?guī)臀裔屢?也希望cpunion來(lái)幫我一下,謝謝!


            #include?
            <iostream>

            typedef?
            void(*fun)(int);

            using?namespace?std;

            template
            <?typename?T?>
            struct?Base
            {
            ????
            void?test()
            ????
            {
            ????????cout?
            <<?"Base"?<<?"\t=\t";
            ????????cout?
            <<?"Base<"?<<?typeid(T).name()?<<?">"?<<?endl;
            ????}

            }
            ;

            template
            <>
            struct?Base?<?void?>
            {
            ????
            void?test()
            ????
            {
            ????????cout?
            <<?"Base"?<<?endl;
            ????}

            }
            ;

            template
            <>
            struct?Base?<?void(?int?)?>
            {
            ????
            void?test()
            ????
            {
            ????????cout?
            <<?"Base"?<<?endl;
            ????}

            }
            ;

            template
            <>
            struct?Base?<?fun?>
            {
            ????
            void?test()
            ????
            {
            ????????cout?
            <<?"Base"?<<?endl;
            ????}

            }
            ;

            template
            <>
            struct?Base?<?int(?string,?int,?char?)?>
            {
            ????
            void?test()
            ????
            {
            ????????cout?
            <<?"Base"?<<?endl;
            ????}

            }
            ;

            int?main(int?argc,?char*?argv[])
            {
            ????Base
            <?void?>?b_void;
            ????Base
            <?void(?int?)?>?b_void_int;
            ????b_void.test();
            ????b_void_int.test();

            ????Base
            <?int(?string,?int,?char?)?>?b_int;
            ????Base
            <?fun?>?b_fun;
            ????b_int.test();
            ????b_fun.test();


            ????Base
            <?Base<?void?>?(?Base?<?int?(?string,?int,?char?)?>?)?>?b_complex;
            ????b_complex.test();

            ????
            return?0;
            }


            posted on 2005-09-29 19:51 可冰 閱讀(2253) 評(píng)論(9)  編輯 收藏 引用 所屬分類: C++

            評(píng)論

            # re: 關(guān)于模板的類型參數(shù) 2005-09-29 21:16 cpunion
            模板的類型參數(shù),只要是類型都是可以接受的。

            template <class T>
            class Base
            {
            };
            定義了一個(gè)類模板,后面都是它的偏特化。

            你的疑問(wèn)應(yīng)該是void(*)(int)類型和void(int)類型的區(qū)別吧?

            void(int)是一個(gè)函數(shù)類型,void(*)(int)是一個(gè)函數(shù)指針類型,函數(shù)類型僅在聲明時(shí)有效,當(dāng)把void(int)類型的函數(shù)作為一個(gè)值來(lái)傳遞時(shí),它自動(dòng)退化為void(*)(int)指針類型。

            關(guān)于這一點(diǎn),最好是看劉未鵬對(duì)于boost::function源代碼的解釋,我也是從這里才知道有這種用法的。  回復(fù)  更多評(píng)論
              

            # re: 關(guān)于模板的類型參數(shù) 2005-09-29 21:23 函數(shù)類型
            void Fun(int);
            cout << typeid(void(int)).name() << endl;
            cout << typeid(Fun).name() << endl;
              回復(fù)  更多評(píng)論
              

            # re: 關(guān)于模板的類型參數(shù) 2005-09-29 21:39 cpunion
            typeid, sizeof, typeof(c++0x)都不取表達(dá)式的值,只提取類型。  回復(fù)  更多評(píng)論
              

            # re: 關(guān)于模板的類型參數(shù) 2005-09-29 22:57 可冰
            void(int)原來(lái)是函數(shù)類型啊!從來(lái)沒(méi)有見到過(guò)這樣的類型啊.
            你所說(shuō)的"當(dāng)把void(int)類型的函數(shù)作為一個(gè)值來(lái)傳遞時(shí),它自動(dòng)退化為void(*)(int)指針類型。"應(yīng)該是指,用它來(lái)定義變量的時(shí)候,這個(gè)變量就成了函數(shù)指針類型的了?  回復(fù)  更多評(píng)論
              

            # re: 關(guān)于模板的類型參數(shù) 2005-09-29 23:08 cpunion
            函數(shù)類型可以用做聲明,也可以表示函數(shù)代碼塊,不能直接用它聲明一個(gè)變量,所以很少見。

            比如函數(shù):

            void func(int)
            {
            }

            func本身是函數(shù)類型,不過(guò)當(dāng)作值來(lái)傳遞給一個(gè)void(*)(int)類型指針時(shí),自動(dòng)退化為指針類型,所以不需要加上&符號(hào),加上&也是合法的。

            使用typeid, typeof都可以獲取到函數(shù)類型。  回復(fù)  更多評(píng)論
              

            # re: 關(guān)于模板的類型參數(shù) 2005-09-29 23:11 可冰
            我在模板中試了一下,確實(shí)用函數(shù)類型定義的變量成為了函數(shù)指針類型.
            定義為: T var;
            輸出為: var: void (__thiscall Base<void __cdecl(int)>::*)(int)
            T : void __cdecl(int)

            但是在外部,定義這樣的一個(gè)類型及變量:
            typedef void MethodType (int);
            MethodType method;

            它們的類型居然是一樣的,method在這兒并沒(méi)有轉(zhuǎn)化為函數(shù)指針類型.
            輸出類型如下:
            void __cdecl(int)
            void __cdecl(int)

            這又是怎么回事?  回復(fù)  更多評(píng)論
              

            # re: 關(guān)于模板的類型參數(shù) 2005-09-29 23:40 cpunion
            在g++編譯器下,T var;是不能編譯通過(guò)的。

            typedef void MethodType (int);
            MethodType method;

            這個(gè)定義確實(shí)能夠通過(guò)編譯(我以前沒(méi)這么測(cè)試過(guò)),因?yàn)閙ethod的是函數(shù)類型,而它沒(méi)有實(shí)際定義,相當(dāng)于寫了一個(gè)函數(shù)聲明,所以如果調(diào)用它,鏈接器將報(bào)錯(cuò)。

            這個(gè)功能本來(lái)是開放給編譯器使用的,所以雖然能夠定義,但無(wú)法操作它,你無(wú)法對(duì)它使用sizeof,無(wú)法對(duì)它取地址,只能對(duì)它使用typeid獲取類型信息、使用typeof獲取它的類型。

            int m;
            typedef void MethodType (int);
            MethodType method;
            int n;

            測(cè)試可以知道,n和m的地址相差是4字節(jié)(32位平臺(tái)上),method并不真的定義了一個(gè)變量。

            應(yīng)該是C++給編譯器定的標(biāo)準(zhǔn),相當(dāng)詭異。。  回復(fù)  更多評(píng)論
              

            # re: 關(guān)于模板的類型參數(shù) 2005-09-30 01:59 說(shuō)得對(duì),僅僅是申明
            typedef void MethodType (int);
            MethodType method;

            extern void method(int);
            基本上一樣,另外,加上定義
            void method(int)
            {
            }
            可以
            method(0);
            這樣用了
              回復(fù)  更多評(píng)論
              

            # re: 關(guān)于模板的類型參數(shù) 2005-09-30 20:51 可冰
            [摘錄](méi)Boost源碼剖析之:泛型函數(shù)指針類boost::function(修訂版)
            劉未鵬 /文

            或許你會(huì)對(duì)模板參數(shù)int(int)感到陌生,其實(shí)它是個(gè)函數(shù)型別——函數(shù)g的確切型別就是int(int),而我們通常所看到的函數(shù)指針型別int (*)(int)則是&g的型別。它們的區(qū)別與聯(lián)系在于:當(dāng)把g作為一個(gè)值進(jìn)行拷貝的時(shí)候(例如,按值傳參),其類型就會(huì)由int(int)退化為int(*)(int),即從函數(shù)類型退化為函數(shù)指針類型——因?yàn)閺恼Z(yǔ)義上說(shuō),函數(shù)不能被“按值拷貝”,但身為函數(shù)指針的地址值則是可以被拷貝的。另一方面,如果g被綁定到引用,則其類型不會(huì)退化,仍保持函數(shù)類型。
            ......
            請(qǐng)注意,函數(shù)類型乃是個(gè)極其特殊的類型,在大多數(shù)時(shí)候它都會(huì)退化為函數(shù)指針類型,以便滿足拷貝語(yǔ)義,只有面對(duì)引用綁定的時(shí)候,能夠維持原來(lái)的類型。當(dāng)然,對(duì)于boost::function,總是按值拷貝。  回復(fù)  更多評(píng)論
              

            日本精品久久久久影院日本 | 久久狠狠爱亚洲综合影院| 国产亚洲精午夜久久久久久| 伊人久久综在合线亚洲2019| 精品久久久久久无码国产| 亚洲国产精品无码久久九九 | 99久久精品国产麻豆| 国产精品青草久久久久婷婷| 久久人人爽人人爽AV片| 五月丁香综合激情六月久久| 国产精品99久久精品爆乳| 一本久道久久综合狠狠躁AV| 久久久久亚洲AV无码永不| 免费一级做a爰片久久毛片潮| 中文国产成人精品久久不卡| 国产高清国内精品福利99久久| 欧美激情一区二区久久久| 久久99亚洲网美利坚合众国| 伊人久久大香线蕉精品不卡 | 久久99精品久久久久久不卡 | 国内精品免费久久影院| 久久精品中文騷妇女内射| 久久久久国产一级毛片高清板 | 久久99精品九九九久久婷婷| 九九精品99久久久香蕉| 一本色道久久88—综合亚洲精品 | 欧美亚洲国产精品久久久久| 88久久精品无码一区二区毛片 | 国产精品热久久无码av| 国产V亚洲V天堂无码久久久| 久久人人爽人人爽人人片AV高清| 99久久精品国产一区二区三区| 久久久久久久97| 久久99这里只有精品国产| 久久久久久久亚洲精品| 国产精品欧美久久久久无广告| 91麻豆精品国产91久久久久久| 99精品国产在热久久无毒不卡| 久久久噜噜噜www成人网| 97久久精品无码一区二区天美| 精品熟女少妇a∨免费久久|