• <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++博客 :: 首頁 :: 聯系 :: 聚合  :: 管理
              16 Posts :: 0 Stories :: 27 Comments :: 0 Trackbacks

            常用鏈接

            留言簿

            我參與的團隊

            搜索

            •  

            最新評論

            閱讀排行榜

            評論排行榜

            看了幾位大嚇的回復,深深地感覺到了這篇附筆中可能存在錯誤,于是把最初遇到此問題時的環境再模擬了一下,現在可以確認這篇附筆中的確存在問題,現在就修正一下,并對各位表示歉意.
            6月初的一個項目中需要寫一個高性能網絡服務端程序,在網上找到了一份很好的代碼(
            請參見),在使用過程中發現在多個cpp文件中引入這份代碼的h文件時,會出現很多重復定義錯誤,當時很頭疼,沒能很好的解決問題.
            現總結一條:在使用類模板技術時,可在.h中實現,也可在.h和.cpp中分開實現,若用.h實現,不要在文件中加入非類模板代碼,可避免重寫定義錯誤..
                  2009年7月25日23時58分58秒
            //////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////
            // 原文如下:Posted on 2009-07-25 15:10 sToa
            //////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////

            1.聲明部分
            // Tpl.h
            #pragma once

            template<class T>
            class CTpl  
            {
            public:
                CTpl();
                virtual ~CTpl();

                void Test(T t);

            };

            2.實現部分
            // Tpl.cpp
            #include "Tpl.h"

            template<class T>
            CTpl<T>::CTpl()
            {

            }

            template<class T>
            CTpl<T>::~CTpl()
            {

            }

            template<class T>
            void CTpl<T>::Test(T t)
            {

            }
            3.習慣錯誤用法
            // main.cpp
            #include "Tpl.h"

            int main()
            {
                CTpl<char> ts;
                ts.Test(3);
                return 0;
            }

            build時出現link錯誤
            main.obj : error LNK2001: unresolved external symbol "public: virtual __thiscall CTpl<char>::~CTpl<char>(void)" (??1?$CTpl@D@@UAE@XZ)
            main.obj : error LNK2001: unresolved external symbol "public: void __thiscall CTpl<char>::Test(char)" (?Test@?$CTpl@D@@QAEXD@Z)
            main.obj : error LNK2001: unresolved external symbol "public: __thiscall CTpl<char>::CTpl<char>(void)" (??0?$CTpl@D@@QAE@XZ)
            這組錯誤信息和project中不加入Tpl.cpp的錯誤信息一樣,即沒有CTpl<char>的實現代碼
            我們把Tpl.cpp包涵到main.cpp中,問題解決
            4.正確用法

            // main.cpp
            #include "tpl.cpp"
            int main()
            {
                CTpl<char> ts;
                ts.Test(3);
                return 0;
            }

            5.總結
            1.在使用以.h,.cpp分離實現模板類時,不能像使用普通類一樣只簡單的包涵.h頭文件,應該在使用模板類的cpp文件中引入模板類相應的cpp文件
            2.將模板類的聲明與實現都放在.h中(在多個cpp中使用不同模板參數時可能會引起重復定義的編譯錯誤)




            posted on 2009-07-25 15:10 sToa 閱讀(9157) 評論(7)  編輯 收藏 引用 所屬分類: C++

            Feedback

            # re: 在類模板的聲明和定義中把.h與.cpp分離 2009-07-25 15:47 99書城
            很好哦!  回復  更多評論
              

            # re: 在類模板的聲明和定義中把.h與.cpp分離 2009-07-25 19:37 cyberamoeba
            Hold a candle to the sun!  回復  更多評論
              

            # re: 在類模板的聲明和定義中把.h與.cpp分離[未登錄] 2009-07-25 20:11 hdqqq
            這個和include .h 文件有啥區別,后綴不同而已。  回復  更多評論
              

            # re: 在類模板的聲明和定義中把.h與.cpp分離 2009-07-25 21:13 legendlee
            這仍然沒有改變模板的本質:你想讓人用,就要提供給人家源碼。  回復  更多評論
              

            # re: 在類模板的聲明和定義中把.h與.cpp分離 2009-07-27 02:15 阿福
            我的習慣是:模板類的定義放在.h文件中,模板類的實現放在.hpp文件中。
            然后.h文件的末尾再include .hpp文件。
            在使用的時候,直接#include .h文件就行了。
            如果擔心編譯效率,可以使用預編譯頭文件技術。  回復  更多評論
              

            # re: 在類模板的聲明和定義中把.h與.cpp分離 2012-03-22 20:25 dh
            很好,解決了我的編譯錯誤問題。原因是什么呢?模板類和普通類有什么區別?  回復  更多評論
              

            # re: 在類模板的聲明和定義中把.h與.cpp分離 2013-07-18 17:37 wt
            @dh
            你把模板只是把代碼展開,如果你不包括實現就就相當沒有實現.
            模板是編譯時展開,不是連接時展開,也是不運行時的虛函數  回復  更多評論
              

            精品久久人人妻人人做精品| 国产精品99久久99久久久| 久久久噜噜噜久久熟女AA片| 久久精品免费网站网| 久久精品国产99久久久香蕉| 一级做a爰片久久毛片16| 久久综合久久久| 日本福利片国产午夜久久| 精品人妻久久久久久888| 蜜臀av性久久久久蜜臀aⅴ| 狠狠综合久久综合88亚洲| 人妻无码精品久久亚瑟影视| 久久久久久久久久久久久久| 久久综合九色综合网站| 超级97碰碰碰碰久久久久最新| 无码人妻久久一区二区三区蜜桃| 久久亚洲日韩看片无码| 久久综合88熟人妻| 国产精品久久免费| 国产激情久久久久影院老熟女| 国产999精品久久久久久| 久久久WWW免费人成精品| 一本色综合久久| 久久一日本道色综合久久| 国产精品久久毛片完整版| 久久久久久国产精品免费免费 | 一级A毛片免费观看久久精品| 中文字幕精品无码久久久久久3D日动漫| 婷婷久久综合九色综合绿巨人| 伊色综合久久之综合久久| 亚洲色婷婷综合久久| 久久中文骚妇内射| 久久精品国产一区二区| 国产成人无码精品久久久性色| 精品久久久久久国产潘金莲| 国产—久久香蕉国产线看观看 | 久久人与动人物a级毛片| AV无码久久久久不卡蜜桃| 久久人人爽人爽人人爽av| 久久久女人与动物群交毛片| 精品久久久久久国产免费了|