• <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>
            隨筆 - 20, 文章 - 0, 評論 - 45, 引用 - 0
            數(shù)據(jù)加載中……

            類模板和模板函數(shù)連接出錯處理

                   對C++編譯器而言,當(dāng)調(diào)用函數(shù)的時候,編譯器只需要看到函數(shù)的聲明。當(dāng)定義類類型的對象時,編譯器只需要知道類的定義,而不需要知道類的實(shí)現(xiàn)代碼。因此,因該將類的定義和函數(shù)聲明放在頭文件中,而普通函數(shù)和類成員函數(shù)的定義放在源文件中。
                   但在處理模板函數(shù)和類模板時,問題發(fā)生了變化。要進(jìn)行實(shí)例化模板函數(shù)和類模板,要求編譯器在實(shí)例化模板時必須在上下文中可以查看到其定義實(shí)體;而反過來,在看到實(shí)例化模板之前,編譯器對模板的定義體是不處理的——原因很簡單,編譯器怎么會預(yù)先知道 typename 實(shí)參是什么呢?因此模板的實(shí)例化與定義體必須放到同一翻譯單元中。
                    以下是模板聲明和定義的兩種方法:
            1)可以通過在聲明函數(shù)模板或類模板的頭文件中添加一條#indlude指示定義可用,引入了包含相關(guān)定義的源文件。
            //set.h file
            #ifndef _SET_H_J
            #define _SET_H_J

            #include 
            <list>

            template
            <class T>
            class Set_j
            {
            public:
                std::size_t size();
                
            void insert(const T& item);
                
            void remove(const T& item);
                
            bool is_has(const T& item);
            private:
                std::list
            <T> m_list;
            };

            #include 
            "set.cpp"

            #endif

            // set.cpp file
            #ifndef _CPP_SET_J
            #define _CPP_SET_J
            #include 
            "set.h"
            #include 
            <algorithm>

            template
            <class T>
            std::size_t Set_j
            <T>::size()
            {
                
            return m_list.size();
            }

            template
            <class T>
            void Set_j<T>::insert(const T& item)
            {
                
            if(!is_has(item))
                {
                    m_list.push_back(item);
                }
            }

            template
            <class T>
            void Set_j<T>::remove(const T& item)
            {
                std::list
            <T>::iterator it = std::find(m_list.begin(),m_list.end(),item);

                
            if(it != m_list.end())
                {
                    m_list.erase(it);
                }
            }

            template
            <class T>
            bool Set_j<T>::is_has(const T& item)
            {
                
            return (std::find(m_list.begin(),m_list.end(),item) != m_list.end());
            }
            #endif

            // main.cpp  file
            #include <iostream>
            #include 
            "set.h"

            void main()
            {
                Set_j
            <int> test;

                std::cout 
            << "size: " << test.size() << std::endl;

                
            int i = 10;

                test.insert(i);
                test.insert(i
            +1);
                test.insert(i
            +2);
                test.insert(i
            +2);

                std::cout 
            << "size: " << test.size() << std::endl;

                test.remove(i
            +2);

                std::cout 
            << "size: " << test.size() << std::endl;
            }

            2)通過關(guān)鍵字export實(shí)現(xiàn)。
                      C++理論上支持模板的分離編譯(也就是支持export關(guān)鍵詞),但是實(shí)際上VC2005,vs2010均不支持,在 VS 2008 中,export 關(guān)鍵字在 IDE 中被標(biāo)藍(lán),表示 VS IDE 認(rèn)識它,而編譯時,會用警告友情提示你“不支持該關(guān)鍵字”。
            3)當(dāng)然就是將定義和實(shí)現(xiàn)文件寫在一個文件中。

            參考文獻(xiàn):
            1.C++ Primer

            posted on 2011-04-23 12:46 Kenny Jiang 閱讀(5401) 評論(3)  編輯 收藏 引用 所屬分類: C++

            評論

            # re: 類模板和模板函數(shù)連接出錯處理  回復(fù)  更多評論   

            樓主所言甚是, 收益中,謝謝
            2011-04-23 14:05 | misserwell

            # re: 類模板和模板函數(shù)連接出錯處理  回復(fù)  更多評論   

            恩,確實(shí)是這樣,一直在使用第一種方法
            2011-04-24 09:22 | winlin

            # re: 類模板和模板函數(shù)連接出錯處理[未登錄]  回復(fù)  更多評論   

            頭文件包含源文件的技巧的確讓模板在物理上變的清晰了,但還是不能隱藏實(shí)現(xiàn),這是模板自身的缺點(diǎn)之一。
            2011-05-02 17:44 | Nickolas
            国产精品xxxx国产喷水亚洲国产精品无码久久一区 | 日韩人妻无码一区二区三区久久 | 一本久久久久久久| 久久精品无码一区二区三区免费 | 午夜精品久久久内射近拍高清| 精品国产日韩久久亚洲| 久久发布国产伦子伦精品| 久久99久久无码毛片一区二区| 热99RE久久精品这里都是精品免费 | 色播久久人人爽人人爽人人片AV| 色综合久久无码五十路人妻| 欧美777精品久久久久网| 久久天天躁狠狠躁夜夜不卡| 国产精品成人无码久久久久久| 99蜜桃臀久久久欧美精品网站| 国产精品久久久久久久久久免费| 久久无码人妻一区二区三区| 亚洲日本va午夜中文字幕久久 | 国产AⅤ精品一区二区三区久久 | 久久国产色AV免费观看| 久久伊人五月丁香狠狠色| 国产精品无码久久综合网| 亚洲日本va中文字幕久久| 亚洲另类欧美综合久久图片区| 93精91精品国产综合久久香蕉 | 久久国产免费直播| 色综合久久综合网观看| 久久久久久夜精品精品免费啦| 日韩欧美亚洲综合久久| 久久伊人精品一区二区三区| 免费无码国产欧美久久18| 伊人色综合九久久天天蜜桃| 人妻中文久久久久| 免费无码国产欧美久久18| 国产成人精品久久| 亚洲午夜久久久久久久久电影网| 久久强奷乱码老熟女网站| 无码超乳爆乳中文字幕久久| 亚洲AV无码久久寂寞少妇| 国产精品久久久久久吹潮| 2022年国产精品久久久久|