• <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>
            隨筆 - 7  文章 - 15  trackbacks - 0
            <2006年6月>
            28293031123
            45678910
            11121314151617
            18192021222324
            2526272829301
            2345678

            常用鏈接

            留言簿(2)

            隨筆檔案(7)

            相冊

            搜索

            •  

            積分與排名

            • 積分 - 15783
            • 排名 - 953

            最新評論

            閱讀排行榜

            評論排行榜

            還是我做的那個鏈表的模板類
            我分別寫了頭文件Chain.h,源文件Chain.cpp,并且在main.cpp中進行測試。
            但是在連接的時候出現(xiàn)了問題,不知道什么原因,希望能夠有高手指點一下,非常感謝!

            其中Chain.h聲明了類的數(shù)據(jù)成員和成員函數(shù),具體內(nèi)容如下:

            #ifndef _CHAIN_H
            #define _CHAIN_H

            #include <iostream>
            using namespace std;

            template<class T>
            class Chain;


            template<class T>
            class ChainNode
            {
            ?friend class Chain<T>;
            ?friend ostream& operator<<(ostream& out, const Chain<T>& x);
            private:
            ?T data;
            ?ChainNode<T> *link;
            };

            template<class T>
            class Chain{

            public:
            ?Chain(int p) {first = 0;};
            ?~Chain();
            ?bool IsEmpty() const {return first == 0;}
            ?int Length() const;
            ?bool Find(int k, T& x) const;
            ?int Search(const T& x) const;
            ?//Chain<T>& Delete(int k, T& x);
            ?Chain<T>& Insert(int k, const T& x);
            ?void Output(ostream& out = cout) const;
            private:
            ?ChainNode<T> *first; // 指向第一個節(jié)點的指針
            };

            template<class T>
            ostream& operator<<(ostream& out, const Chain<T>& x);

            #endif? // _CHAIN

            ??在Chain.cpp中對Chain.h中聲明的函數(shù)進行了定義,具體內(nèi)容如下:

            #include "Chain.h"
            #include <iostream>
            using namespace std;

            template<class T>
            Chain<T>::~Chain()
            {
            ?//鏈表的析構函數(shù),用于刪除鏈表中的所有節(jié)點
            ?ChainNode<T> *ptr = first;
            ?while (ptr)
            ?{
            ??first = ptr->link;
            ??delete ptr;
            ??ptr = first;
            ?}
            }

            template<class T>
            int Chain<T>::Length() const
            {
            ?//返回鏈表中的元素總數(shù)
            ?int count = 0;
            ?ChainNode<T> *ptr = first;
            ?while (ptr)
            ?{
            ??++count;
            ??ptr = ptr->link;
            ?}
            ?return count;
            }

            template<class T>
            bool Chain<T>::Find(int k, T& x) const
            {
            ?//尋找鏈表中的第k個元素,并將其傳送至x
            ?//如果不存在第k個元素,則返回false,否則返回true
            ?if (k < 1)
            ?{
            ??return false;
            ?}
            ?int count = k;
            ?ChainNode<T> *ptr = first;
            ?while (count && ptr)
            ?{
            ??--count;
            ??ptr = ptr->link
            ?}
            ?if (!ptr)
            ?{
            ??return false;
            ?}
            ?x = ptr->data;
            ?return true;
            }

            template<class T>
            int Chain<T>::Search(const T& x) const
            {
            ?//尋找x,如果發(fā)現(xiàn)x,則返回x的地址
            ?//如果x不在鏈表中,則返回0
            ?int count = 1;
            ?ChainNode<T> *ptr = first;
            ?while(ptr && (ptr->data!=x))
            ?{
            ??++count;
            ??ptr = ptr->link;
            ?}
            ?if (ptr)
            ?{
            ??return count;
            ?}
            ?else
            ?{
            ??return 0;
            ?}
            }

            template<class T>
            void Chain<T>::Output(ostream& out = cout) const
            {
            ?ChainNode<T> *ptr = first;
            ?while (ptr)
            ?{
            ??out<<ptr->data<<"? ";
            ??ptr = ptr->link;
            ?}
            }

            //重載<<運算符
            template<class T>
            ostream& operator<<(ostream& out, const Chain<T>& x)
            {
            ?x.Output(out);
            ?return out;
            }

            template<class T>
            Chain<T>& Chain<T>::Insert(int k, const T& x)
            {
            ?ChainNode<T> *ptr = first;
            ?int count = 0;
            ?while (ptr && count < k)
            ?{
            ??++count;
            ??ptr = ptr->link;
            ?}
            ?if (!ptr)? //如果沒到第k個節(jié)點
            ?{
            ?
            ?}
            ?else
            ?{
            ??//要插入的新節(jié)點
            ??ChainNode<T>* cn = new ChainNode<T>;
            ??cn->data = x;
            ??cn->link = 0;
            ??if (ptr->link==0)? //到達了鏈表的結尾
            ??{
            ???ptr->link = cn;
            ??}
            ??else? //沒到達結尾
            ??{?
            ???cn->link = ptr->link;
            ???ptr->link = cn;
            ??}
            ?}
            ?return *this
            }

            ?在main.cpp中進行測試,測試的內(nèi)容很少,但是剛開始就進行不了了。main.cpp內(nèi)容如下:

            #include "Chain.h"
            using namespace std;

            int main()
            {
            ?Chain<int> c;
            ?cout<<c.Length();
            ?return 0;
            }

            編譯的時候沒有問題,但是在連接的時候就出現(xiàn)了問題,報錯如下:
            --------------------Configuration: Chain - Win32 Debug--------------------
            Linking...
            main.obj : error LNK2001: unresolved external symbol "public: __thiscall Chain<int>::~Chain<int>(void)" (
            ??1?$Chain@H@@QAE@XZ)
            main.obj : error LNK2001: unresolved external symbol "public: int __thiscall Chain<int>::Length(void)const " (
            ?Length@?$Chain@H@@QBEHXZ)
            Debug/Chain.exe : fatal error LNK1120: 2 unresolved externals
            Error executing link.exe.

            Chain.exe - 3 error(s), 0 warning(s)
            但是從報錯信息來看,應該是在main.cpp中沒有找到所用到的函數(shù) ~Chain<int>(void)和Length()的定義,在main.cpp中一共用到了三個函數(shù),構造函數(shù)Chain(),但是構造函數(shù)是在Chain.h中定義的,所以編譯器找到了其定義,但是另外兩個函數(shù)是在Chain.cpp中定義的,而且目前報錯沒有找到,但是如果在main.cpp中引入#include "Chain.cpp"時,編譯和連接就沒有問題,這就證實了原來的估計是沒有錯的。我實在是不知道問題出現(xiàn)在哪里,所以希望哪位高手看出問題來的話,請告訴我,多謝了!

            posted on 2006-06-19 16:56 Bourne 閱讀(846) 評論(4)  編輯 收藏 引用

            FeedBack:
            # re: VC++中的連接問題,請大俠幫忙,我快崩潰了 2006-06-19 18:20 CoderDream
            將Chain.h 和 Chain.cpp 合并成一個文件,然后修改主函數(shù)中的第一句:
            Chain<int> c(666);//要帶參數(shù),不然沒有匹配的構造函數(shù)

            但是運行結果為0,顯然不對,再看看哪里出了問題。

            有模板時最好將函數(shù)的聲明和定義寫在同一個文件中  回復  更多評論
              
            # re: VC++中的連接問題,請大俠幫忙,我快崩潰了 2006-06-19 18:54 萬連文
            模板的實現(xiàn)最好在.h里面,如果非要象你那樣也可以,在.h里面包含.cpp。  回復  更多評論
              
            # re: VC++中的連接問題,請大俠幫忙,我快崩潰了 2006-06-19 20:01 笑笑生
            #include "Chain.h"->#include "Chain.cpp"
            using namespace std;

            int main()
            {
            Chain<int> c;
            cout<<c.Length();
            return 0;
            }  回復  更多評論
              
            # re: VC++中的連接問題,請大俠幫忙,我快崩潰了 2006-06-19 21:44 Bourne
            我采取在main.cpp直接引入Chain.cpp的方法了

            #include "Chain.h"->#include "Chain.cpp"
            多謝各位的幫助阿!  回復  更多評論
              
            久久久免费精品re6| 国产精品久久毛片完整版| 国产L精品国产亚洲区久久| 久久99精品国产一区二区三区| 91精品无码久久久久久五月天| 蜜桃麻豆www久久| 99久久做夜夜爱天天做精品| 伊人色综合久久天天人手人婷| 久久青青草原精品影院| 久久只有这里有精品4| 久久久久久夜精品精品免费啦| 亚洲国产精品久久久久网站| 99精品国产综合久久久久五月天| 2021久久精品国产99国产精品| 久久精品综合一区二区三区| 国产精品久久婷婷六月丁香| 日本精品久久久中文字幕| 青青青青久久精品国产h久久精品五福影院1421| 久久久久久综合网天天| 久久精品不卡| 久久综合久久综合久久| 综合久久国产九一剧情麻豆| 日韩久久久久中文字幕人妻| 狠狠色丁香久久综合婷婷| 无码专区久久综合久中文字幕| 老司机午夜网站国内精品久久久久久久久 | 久久伊人影视| 久久精品草草草| 久久免费的精品国产V∧| 久久AV无码精品人妻糸列| 久久免费99精品国产自在现线| 狠狠精品久久久无码中文字幕| www性久久久com| 国产精品9999久久久久| 久久久久人妻精品一区| 国产成人精品久久| 亚洲精品无码成人片久久| 亚洲午夜久久久影院| 亚洲AV乱码久久精品蜜桃| 久久久久久久久无码精品亚洲日韩| 婷婷五月深深久久精品|