青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品

MyMSDN

MyMSDN記錄開發(fā)新知道

關(guān)于C++ Template分離頭文件和定義所產(chǎn)生的錯誤

編譯錯誤

如圖所示的代碼出現(xiàn)了如圖所示的錯誤,誰能解釋一下是為什么呢?

雖然在最后include進了cpp文件,而且這種做法也在C++ Primer中也是正確的(難道是標準和現(xiàn)實的差距?)。將代碼稍微變動,并將cpp部分的內(nèi)容移到.h文件中的include位置即可正確編譯。

編譯正確

posted on 2009-02-22 06:05 volnet 閱讀(4350) 評論(20)  編輯 收藏 引用

評論

# re: 關(guān)于C++ Template分離頭文件和定義所產(chǎn)生的錯誤 2009-02-22 09:12 huoxd

我記著這是個老問題了,的確不少的參考書中這么說過,但是要注意兩點:
1.這樣的分離只是文件層面的分離,并非是傳統(tǒng)的模塊之間只見接口,不見實現(xiàn)的分離,做為沒用動態(tài)特性的靜態(tài)語言,C++把模板的實現(xiàn)封裝成二進制是不可能的,這種編程技巧只是為了讓代碼瀏覽起來感覺更規(guī)范.
2.不同的編譯器對模板的實現(xiàn)還沒有完全按照標準來支持,所以產(chǎn)生錯誤了不奇怪.  回復  更多評論   

# re: 關(guān)于C++ Template分離頭文件和定義所產(chǎn)生的錯誤 2009-02-22 09:14 huoxd

是"沒有動態(tài)特性"的,打錯了,不好意思  回復  更多評論   

# re: 關(guān)于C++ Template分離頭文件和定義所產(chǎn)生的錯誤 2009-02-22 12:04 空明流轉(zhuǎn)

在源代碼級別,模板是可以有一定程度的分離的.

我舉個例子

//lib.h
template <class T> const T& return_itself(const T& val);

//lib.cpp
template <class T> const T& return_itself(const T& val){ return val; }
void instantiate_return_itself(){
//this is not executing factually.
return_itself((int)0);
}

//app.cpp
#include "lib.h"

int main(){
return_itself((int)0); // OK
return_itself(0.0f); // no compiler error happens but some link errors
}  回復  更多評論   

# re: 關(guān)于C++ Template分離頭文件和定義所產(chǎn)生的錯誤 2009-02-22 12:37 huoxd

樓上說的是模板函數(shù),的確可以分離,但模板類就不太容易了  回復  更多評論   

# re: 關(guān)于C++ Template分離頭文件和定義所產(chǎn)生的錯誤 2009-02-22 18:23 Dancefire

樓主,你的問題其實很簡單。

你是不是把foo.cpp也放進Visual C++的項目里了?如果是的話,這樣會導致foo.cpp的編譯,這個編譯會導致T Foo<T>::GetInstance(void)被編譯實現(xiàn)。當繼續(xù)編譯main.cpp的時候,就會報告,T Foo<T>::GetInstance(void)已經(jīng)有一個實例了。

解決辦法很簡單,把foo.cpp移出工程就可以了。只要物理上foo.h的同目錄存在foo.cpp這個文件就可以了。因為foo.cpp根本沒必要去編譯。甚至我都不建議你稱其為foo.cpp,不如叫什么foo_impl.hpp之類的文件名更合理些,這樣即使這個文件在工程里面也不回導致被編譯。  回復  更多評論   

# re: 關(guān)于C++ Template分離頭文件和定義所產(chǎn)生的錯誤 2009-02-22 19:36 chujun

Foo.cpp里改成:
#ifndef FOO_H_
#include "foo.h"
template<typename T> T Foo<T>::GetInstance() {
return instance;
}
#endif
可以試一下...  回復  更多評論   

# re: 關(guān)于C++ Template分離頭文件和定義所產(chǎn)生的錯誤 2009-02-22 20:57 yindf

Dancefire 的答案是對的,如果你自己寫makefile的話,肯定不能把foo.cpp編譯成foo.obj。

書上沒有說這一點,但是你的IDE自動幫你makefile了,所以有些時候,自動化也有不好的地方呀。  回復  更多評論   

# re: 關(guān)于C++ Template分離頭文件和定義所產(chǎn)生的錯誤 2009-02-22 22:26 volnet

@Dancefire
的確,把foo.cpp移出項目外的話就可以順利編譯并執(zhí)行了!
但是在你的回答中,為什么會提到“當繼續(xù)編譯main.cpp的時候……”,這是為什么呢?為什么非模板類型就可以?  回復  更多評論   

# re: 關(guān)于C++ Template分離頭文件和定義所產(chǎn)生的錯誤 2009-02-22 23:11 空明流轉(zhuǎn)

非模板類型的應該也是不可以的。
還有就是,不僅僅是模板函數(shù),模板類一樣可以。  回復  更多評論   

# re: 關(guān)于C++ Template分離頭文件和定義所產(chǎn)生的錯誤 2009-02-22 23:15 volnet

@空明流轉(zhuǎn)
我說的可以是指在h中聲明,在cpp中定義,這顯然是可以的(也是標準的做法)
模板函數(shù)和模板類的確都存在如本文所述的問題,并且用Dancefire的方法,或者使用全部寫在.h文件中的方式,都是可以的。  回復  更多評論   

# re: 關(guān)于C++ Template分離頭文件和定義所產(chǎn)生的錯誤 2009-02-23 00:49 Dancefire

@volnet
呵呵,非模板類型的函數(shù)定義我們也不會需要在foo.h中include foo.cpp啊:)

在樓主的例子里面為了能夠讓定義和聲明分開,將聲明放到了foo.h中,而定義放到了foo.cpp中,這和非模板類型的函數(shù)是一樣的。但是可惜這么做是無法通過的,因為模板類型函數(shù)不能夠(由于沒有export支持)單獨編譯。為了讓編譯通過,樓主將foo.cpp給include進了foo.h,這樣實際上是將兩個文件整合成一個文件了。這樣編譯就沒有問題了,但是得小心需要把foo.cpp分離出項目,因為它不可以被編譯;或者將其擴展名從.cpp改為.hpp。

實在是不推薦樓主這么分開的寫,說實話這算不上是什么標準的做法,而且這樣并沒有太大的意義。如果非要分開,可以將定義后綴到聲明后面,在一個文件里。但是分開確實沒太大意義。可以研讀一下boost里面的做法。  回復  更多評論   

# re: 關(guān)于C++ Template分離頭文件和定義所產(chǎn)生的錯誤 2009-02-23 00:54 volnet

@Dancefire
原來你們說的是include foo.cpp

分開有一個好處就是可以成套地替換吧,雖然通常我們不這么做,但是卻從語法上支持了這么做。如果可以當然好了,不行的話肯定是沒辦法的。  回復  更多評論   

# re: 關(guān)于C++ Template分離頭文件和定義所產(chǎn)生的錯誤 2009-02-23 00:57 volnet

@Dancefire
boost在C++中的地位是什么呢?一個工業(yè)庫?一個泛型標準?一個開源范例?它對C++學習有什么好處呢?  回復  更多評論   

# re: 關(guān)于C++ Template分離頭文件和定義所產(chǎn)生的錯誤 2009-02-23 01:17 Dancefire

@volnet
Boost可以稱其為是一套準標準庫。它項目建立的目的之一就是為未來的C++標準庫提供候選方案,目前已經(jīng)有將近十個Boost庫成功的成為了C++標準預案。

它的優(yōu)勢很多,首先是代碼使用現(xiàn)代C++的語法,因此namespace, 異常, 模板之類的C++特性會被充分挖掘利用,代碼從設(shè)計、實現(xiàn)到文檔都具有了相當高的水準。另外,由于它使用的是標準C++語法編寫,因此它的可移植性非常的好。當然,針對一些存在問題的編譯器,它也會進行相應的調(diào)整以盡量支持。

Boost這種優(yōu)良的庫,涵蓋的領(lǐng)域很廣,可以說是標準庫很好的補充。另外絕大多數(shù)Boost庫都不需要編譯鏈接,大部分的Boost庫僅僅include頭文件即可工作。我看到國內(nèi)很多人提到Boost的時候說它比較難以編譯安裝云云。其實沒必要編譯,絕大多數(shù)的庫僅僅是由頭文件組成的,只要include進來就可以用了。

Boost是C++強有力的工具,學習C++,除了標準語法和STL外,Boost是必須熟悉的,否則,工程上很有可能會做一些Boost已經(jīng)實現(xiàn)很久的東西,除了重復開發(fā)外,而且你的代碼的質(zhì)量和可持續(xù)性比Boost差很遠,造成項目質(zhì)量的下降。  回復  更多評論   

# re: 關(guān)于C++ Template分離頭文件和定義所產(chǎn)生的錯誤 2009-02-23 01:22 volnet

@Dancefire
謝謝你對Boost做了詳細的介紹。
那么,學習Boost庫需要有哪些準備工作?(假設(shè)從初學者開始)學習Boost庫又有哪些方法或者經(jīng)典的做法呢?(比如什么書,或者什么文檔)  回復  更多評論   

# re: 關(guān)于C++ Template分離頭文件和定義所產(chǎn)生的錯誤 2009-02-23 13:29 maosher

foo.h里面最下面倒數(shù)第二行

的#include   回復  更多評論   

# re: 關(guān)于C++ Template分離頭文件和定義所產(chǎn)生的錯誤 2009-02-23 13:34 volnet

@maosher
怎么了?  回復  更多評論   

# re: 關(guān)于C++ Template分離頭文件和定義所產(chǎn)生的錯誤 2009-02-23 16:22 陳梓瀚(vczh)

template特化是鏈接期不能解決的問題,因此必須放進.h,不要使用別扭的技巧來分離。其實直接寫在一個class{}里面反而漂亮得多。  回復  更多評論   

# re: 關(guān)于C++ Template分離頭文件和定義所產(chǎn)生的錯誤 2009-03-02 11:20 xcj

簡單的問題。把foo.cpp中#include "foo.h"那行刪除掉應該就沒問題了。  回復  更多評論   

# re: 關(guān)于C++ Template分離頭文件和定義所產(chǎn)生的錯誤 2012-01-02 20:27 wzm

.cpp 的模板前面加個 export試試  回復  更多評論   

特殊功能
 
青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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>
            麻豆成人综合网| 在线成人www免费观看视频| 一区二区三区精品久久久| 欧美激情欧美狂野欧美精品| 免费观看亚洲视频大全| 欧美激情亚洲另类| 最新国产成人av网站网址麻豆 | 最新热久久免费视频| 亚洲精品在线观看视频| 亚洲欧美国产77777| 久久久91精品国产| 亚洲国产mv| 亚洲视频一二| 久久综合九色九九| 国产精品国产三级国产专播品爱网 | 免费人成网站在线观看欧美高清| 老司机成人网| 亚洲精品之草原avav久久| 99视频一区| 欧美专区一区二区三区| 欧美久久99| 黄网站免费久久| 亚洲色图综合久久| 免费不卡中文字幕视频| 中国女人久久久| 鲁大师成人一区二区三区| 国产精品乱码久久久久久| 最新中文字幕一区二区三区| 久久久www成人免费无遮挡大片| 亚洲三级免费| 久久深夜福利免费观看| 国产精品一区二区三区久久| 国产欧美大片| 黄色日韩网站| 正在播放亚洲| 狂野欧美一区| 亚洲欧美一区二区三区在线| 欧美激情国产日韩| 尤物网精品视频| 亚洲欧美日韩另类| 亚洲激情在线激情| 久久美女性网| 国产一区欧美日韩| 久久激情网站| 亚洲在线免费视频| 欧美四级电影网站| 一本高清dvd不卡在线观看| 免费在线观看精品| 欧美一级视频精品观看| 国产精品视频精品| 亚洲最新色图| 亚洲激情中文1区| 你懂的视频欧美| 一区在线免费| 麻豆国产精品一区二区三区 | 激情久久综艺| 久久久久久黄| 久久成人免费网| 国产欧美日韩亚洲精品| 午夜免费久久久久| 亚洲欧美韩国| 狠狠网亚洲精品| 麻豆精品在线视频| 久久影音先锋| 亚洲国产精品嫩草影院| 欧美高清不卡在线| 欧美国产日韩二区| 一区二区三区精密机械公司| 91久久精品国产91久久性色tv | 国产一区二区成人| 久久综合婷婷| 麻豆视频一区二区| 99re6热在线精品视频播放速度| 欧美大片91| 欧美精品在线免费| 亚洲欧美国产三级| 欧美亚洲一级片| 亚洲大片精品永久免费| 亚洲国产婷婷综合在线精品| 欧美日韩视频在线第一区| 午夜精品久久久久久久99水蜜桃| 亚洲欧美日韩直播| 91久久精品国产91久久| 亚洲精品无人区| 国产女人水真多18毛片18精品视频| 久久精品女人| 欧美丰满少妇xxxbbb| 亚洲欧美中文日韩在线| 久久中文久久字幕| 亚洲精品一区二区网址| 免费在线看一区| 在线一区二区视频| 性色av一区二区三区红粉影视| 在线观看亚洲视频| 日韩小视频在线观看专区| 国产午夜精品视频| 91久久国产自产拍夜夜嗨| 国产精品视频一区二区三区 | 久久久久一区| 欧美日韩国产欧美日美国产精品| 欧美一区二区三区在线看| 久久综合影视| 午夜在线一区二区| 欧美国产视频日韩| 久久久久久国产精品mv| 欧美日韩免费在线观看| 久久久久久网站| 国产精品久久久久99| 欧美激情在线播放| 国内精品久久国产| 在线一区二区三区做爰视频网站| 影音先锋亚洲一区| 亚洲你懂的在线视频| 这里只有精品视频| 你懂的视频欧美| 欧美77777| 精品91在线| 欧美一区在线直播| 久久电影一区| 国产精品一区二区在线观看| 宅男66日本亚洲欧美视频| 99一区二区| 欧美精品国产精品日韩精品| 欧美国产欧美亚洲国产日韩mv天天看完整| 国产乱码精品| 亚洲在线视频一区| 亚洲宅男天堂在线观看无病毒| 欧美成人精品h版在线观看| 蜜臀av在线播放一区二区三区| 国产日韩av在线播放| 亚洲欧美日韩天堂一区二区| 亚洲一区中文字幕在线观看| 欧美三级第一页| 一本大道久久a久久综合婷婷| 亚洲精品综合| 欧美区视频在线观看| 亚洲日本va午夜在线电影| 亚洲精品社区| 欧美日韩国产成人在线| 亚洲精品欧洲精品| 亚洲视频在线一区| 国产精品久久久久久久7电影| 国产精品99久久久久久久女警 | 亚洲国产日韩欧美一区二区三区| 久久久中精品2020中文| 欧美大片在线观看一区二区| 亚洲国产三级网| 欧美日韩一区精品| 亚洲欧美网站| 免费久久99精品国产自| 亚洲毛片网站| 国产精品久久久久国产精品日日| 亚洲一区二区三区乱码aⅴ蜜桃女| 亚洲日产国产精品| 91久久精品一区二区三区| 久久久久在线观看| 亚洲大胆视频| 在线视频一区观看| 国产精品高潮呻吟久久av无限| 亚洲一级网站| 久久亚洲视频| 一区二区三区欧美在线| 国产精品色一区二区三区| 久久精品国产一区二区三区| 亚洲黄色成人| 午夜国产精品视频免费体验区| 国产一区二区三区久久精品| 美玉足脚交一区二区三区图片| 亚洲精一区二区三区| 欧美一区二区视频在线观看2020| 一区二区三区亚洲| 欧美日韩小视频| 久久av资源网站| 欧美影院一区| 国产在线播精品第三| 亚洲免费影视第一页| 亚洲午夜一区二区三区| 久久精品视频在线观看| 亚洲电影自拍| 欧美三级资源在线| 久久成年人视频| 999亚洲国产精| 久久久久免费观看| 亚洲天堂成人在线观看| 精品二区视频| 国产精品久久久久免费a∨大胸 | 久久婷婷丁香| 夜夜嗨av一区二区三区中文字幕| 久久精品视频va| 一区二区日韩| 亚洲国产成人精品女人久久久 | 国内视频一区| 国产精品一区毛片| 美国十次成人| 午夜综合激情| 亚洲色无码播放| 亚洲日韩第九十九页| 嫩模写真一区二区三区三州| 久久国产精品99久久久久久老狼| 中文精品视频一区二区在线观看|