• <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>
            萬(wàn)星星@豌豆莢 歡迎加入我們
            一個(gè)吃軟飯的男人!!!!!我只想寫(xiě)程序####
            微博:http://weibo.com/wanlianwen
            posts - 172,  comments - 1253,  trackbacks - 0

            模板是一種源碼復(fù)用技術(shù),在某些情況下使用它可以使代碼看起來(lái)非常優(yōu)雅,著名的boost庫(kù)就是模板發(fā)揚(yáng)的典范.
            然而模板也存在弊端,大量使用模板可能導(dǎo)致代碼膨脹.下面介紹一種解決的方案:

            我們首先看一段一般代碼:

            template < typename?T >
            class ?Vector
            {
            public :
            ????
            virtual ? void ?Say()
            ????
            {
            ????????
            const ?type_info & ????t? = ?typeid(T);
            ????????std::cout?
            << ? " Vector< " ? << ?t.name()? << ? " >::Hello " ? << ?std::endl;
            ????}

            }
            ;

            // ?特例化
            template <>
            class ??Vector < void *>
            {
            public :
            ????
            virtual ? void ?Say()
            ????
            {
            ????????std::cout?
            << ? " Vector<void*>::Hello " ? << ?std::endl;
            ????}

            }
            ;

            int ?_tmain( int ?argc,?_TCHAR * ?argv[])
            {
            ????Vector
            < int *> ????pIntVec;
            ????pIntVec.Say();
            ????Vector
            < double *> ????pDoubleVec;
            ????pDoubleVec.Say();
            ????
            return ? 0 ;
            }


            輸出:
            Vector<int *>::Hello
            Vector<double *>::Hello
            從這里,我們可以看出程序在運(yùn)行的過(guò)程中生產(chǎn)了兩分Vector的代碼(int*和double*),盡管這里有特例化,然而類(lèi)型不匹配,編譯器在編譯過(guò)程中無(wú)法定位到特例化版本.如果這個(gè)Vector被濫用的化,我想即使是一個(gè)中等規(guī)模的程序也可能耗費(fèi)成兆字節(jié)的代碼控件.

            我們必須尋找一種中間橋梁使編譯器在編譯過(guò)程中定位到void*的特例化版本.按照模板選擇策略,編譯器總是選擇最特例化的模板,我們可以通過(guò)一個(gè)中間的模板聯(lián)系起上面兩個(gè)版本的模板.下面看一段代碼:

            template < typename?T >
            class ?Vector
            {
            public :
            ????
            virtual ? void ?Say()
            ????
            {
            ????????std::cout?
            << ? " Vector::Hello " ? << ?std::endl;
            ????}

            }
            ;

            // ?特例化
            template <>
            class ??Vector < void *>
            {
            public :
            ????
            virtual ? void ?Say()
            ????
            {
            ????????std::cout?
            << ? " Vector<void*>::Hello " ? << ?std::endl;
            ????}

            }
            ;

            // ?特例化
            template < typename?T >
            class ?Vector < T *> ?:? public ?Vector < void *>
            {
            }
            ;

            int ?_tmain( int ?argc,?_TCHAR * ?argv[])
            {
            ????Vector
            < int *> ????pIntVec;
            ????pIntVec.Say();
            ????Vector
            < double *> ????pDoubleVec;
            ????pDoubleVec.Say();
            ????
            return ? 0 ;
            }


            輸出:
            Vector<void*>::Hello
            Vector<void*>::Hello
            從這里,我們可以看出程序在運(yùn)行過(guò)程中全部使用Vector<void*>的版本.class Vector<T*>模板便是關(guān)鍵的環(huán)節(jié).編譯器在編譯過(guò)程中,由于class Vector<T*>比class Vector更特例化,所以遇到Vector<int*>和Vector<double*>時(shí)都選擇class Vector<T*>,而class Vector<T*>繼承Vector<void*>,一個(gè)更加特例化版本,所以編譯器不再產(chǎn)生新的模板而采用Vector<void*>這個(gè)最特例化版本,這樣所有指針模板都?xì)w結(jié)到Vector<void*>,而class Vector<T*>為用戶(hù)提供了一個(gè)精美而且安全的界面,而Vector<void*>作為底層實(shí)現(xiàn)細(xì)節(jié)被隱藏.

            以上代碼在VC 7.1(VS2003)中編譯通過(guò),由于VC6對(duì)模板支持不好,所以模板的高級(jí)用法一般不要在VC6中使用.
            下載演示代碼

            posted on 2006-03-27 18:54 萬(wàn)連文 閱讀(2338) 評(píng)論(7)  編輯 收藏 引用 所屬分類(lèi): 模板

            FeedBack:
            # re: 抑制模板代碼膨脹的一種技術(shù)
            2006-03-27 20:08 | vender
            不要這么別扭吧,直接偏特化好了
            template<typename T>
            class Vector<T*>
            {
            public:
            virtual void Say()
            {
            std::cout << "Vector<void*>::Hello" << std::endl;
            }
            };
              回復(fù)  更多評(píng)論
              
            # re: 抑制模板代碼膨脹的一種技術(shù)
            2006-03-27 20:15 | vender
            而且你提到的這個(gè)“技巧”還是無(wú)法避免代碼膨脹

            由于此例過(guò)于簡(jiǎn)單,打開(kāi)優(yōu)化的編譯器有可能僅僅產(chǎn)生一份代碼,但原則上(例如不打開(kāi)優(yōu)化等)Vector<int*>和Vector<double*>還是會(huì)產(chǎn)生兩份代碼  回復(fù)  更多評(píng)論
              
            # re: 抑制模板代碼膨脹的一種技術(shù)
            2006-03-28 11:25 | 萬(wàn)連文
            你指的麻煩我主要是為了演示效果,看編譯器到底調(diào)用哪個(gè)版本,
            你指的過(guò)于簡(jiǎn)單也沒(méi)有道理,舉一反三,兩個(gè)難道不能代表問(wèn)題嗎??如果不能我可以寫(xiě)3個(gè),并且我沒(méi)有打開(kāi)任何優(yōu)化器,結(jié)果顯示確實(shí)是一份代碼。順便提一下,這個(gè)技術(shù)是看C++ program language(C++之父)里面提到的,感覺(jué)很好玩,所以動(dòng)手測(cè)試了一下,發(fā)現(xiàn)真可以運(yùn)做。  回復(fù)  更多評(píng)論
              
            # re: 抑制模板代碼膨脹的一種技術(shù)
            2006-03-28 11:41 | 小明
            我覺(jué)得vendor兄說(shuō)的有道理阿,直接對(duì)T*進(jìn)行偏特話就ok了。多一個(gè)void *的版本有什么意義呢?  回復(fù)  更多評(píng)論
              
            # re: 抑制模板代碼膨脹的一種技術(shù)
            2006-03-28 11:48 | 萬(wàn)連文
            如果沒(méi)有void *版本,你可以把
            public:
            virtual void Say()
            {
            std::cout << "Vector::Hello" << std::endl;
            }
            放到
            // 特例化
            template<typename T>
            class Vector<T*> : public Vector<void*>
            {
            };
            看下結(jié)果是不是產(chǎn)生兩份代碼  回復(fù)  更多評(píng)論
              
            # re: 抑制模板代碼膨脹的一種技術(shù)
            2006-03-28 11:50 | 萬(wàn)連文
            最終目的就是讓所有指針模板使用<void *>那一份代碼,這樣減少代碼膨脹  回復(fù)  更多評(píng)論
              
            # re: 抑制模板代碼膨脹的一種技術(shù)
            2006-03-29 15:05 | 萬(wàn)連文
            不好意思,今天再次體會(huì)了一下,上面示例和解釋存在問(wèn)題:
            在特例化的例子里面確實(shí)生成了2個(gè)版本的類(lèi)<double*>和<int*>,這種技術(shù)減少代碼主要表現(xiàn)在函數(shù)體公用上面,比如一個(gè)20行的函數(shù)pushback,實(shí)例化20次(20個(gè)指針版本)就是400行代碼,如果公用<void*>版本,假設(shè)每個(gè)調(diào)用<void*>版本是4行,加上<void*>版本的20行將是20*4+20=100行,確實(shí)減少不少代碼。
            不知道這次理解是否正確。  回復(fù)  更多評(píng)論
              
            簡(jiǎn)歷下載
            聯(lián)系我

            <2007年6月>
            272829303112
            3456789
            10111213141516
            17181920212223
            24252627282930
            1234567

            常用鏈接

            留言簿(66)

            隨筆分類(lèi)

            隨筆檔案

            相冊(cè)

            搜索

            •  

            最新評(píng)論

            閱讀排行榜

            評(píng)論排行榜

            一本大道久久香蕉成人网| 国产成人无码精品久久久性色| 亚洲国产欧洲综合997久久| 久久久精品久久久久特色影视| 久久成人影院精品777| 久久超乳爆乳中文字幕| 狼狼综合久久久久综合网| 久久久久久曰本AV免费免费| 亚洲精品无码久久久| 四虎亚洲国产成人久久精品| 久久免费视频6| 久久中文字幕无码专区| 亚洲国产精品嫩草影院久久| 无码国内精品久久人妻麻豆按摩| 久久久久久久亚洲精品| 亚洲精品国产综合久久一线| 久久婷婷五月综合色奶水99啪| 久久午夜福利无码1000合集| 亚洲va久久久噜噜噜久久天堂| 亚洲AV日韩精品久久久久久久| 色综合久久久久久久久五月| 乱亲女H秽乱长久久久| 久久青草国产手机看片福利盒子| 亚洲天堂久久精品| 综合久久一区二区三区| 欧美午夜精品久久久久免费视| 99久久精品影院老鸭窝| 久久国产精品免费一区二区三区| 欧美麻豆久久久久久中文| 精品国产乱码久久久久久人妻 | 丁香五月网久久综合| 久久精品蜜芽亚洲国产AV| 亚洲国产精品热久久| 欧美日韩精品久久久免费观看| 久久亚洲AV无码精品色午夜| 97久久超碰国产精品2021| 狠狠色丁香婷婷综合久久来来去| 中文字幕无码久久人妻| 99久久精品国产麻豆| 无码任你躁久久久久久久| 91精品国产综合久久久久久|