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

MyMSDN

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

關于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 閱讀(4357) 評論(20)  編輯 收藏 引用

評論

# re: 關于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: 關于C++ Template分離頭文件和定義所產(chǎn)生的錯誤 2009-02-22 09:14 huoxd

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

# re: 關于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: 關于C++ Template分離頭文件和定義所產(chǎn)生的錯誤 2009-02-22 12:37 huoxd

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

# re: 關于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: 關于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: 關于C++ Template分離頭文件和定義所產(chǎn)生的錯誤 2009-02-22 20:57 yindf

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

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

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

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

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

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

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

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

# re: 關于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: 關于C++ Template分離頭文件和定義所產(chǎn)生的錯誤 2009-02-23 00:54 volnet

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

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

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

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

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

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

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

Boost這種優(yōu)良的庫,涵蓋的領域很廣,可以說是標準庫很好的補充。另外絕大多數(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: 關于C++ Template分離頭文件和定義所產(chǎn)生的錯誤 2009-02-23 01:22 volnet

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

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

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

的#include   回復  更多評論   

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

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

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

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

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

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

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

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


只有注冊用戶登錄后才能發(fā)表評論。
網(wǎng)站導航: 博客園   IT新聞   BlogJava   博問   Chat2DB   管理


特殊功能
 
青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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>
            国产精品ⅴa在线观看h| 免费成人美女女| 欧美粗暴jizz性欧美20| 欧美国产视频一区二区| 久久精品二区亚洲w码| 欧美日韩国产美| 99视频精品| 亚洲激情在线观看| 久久噜噜亚洲综合| 国产日韩在线播放| 欧美一区二区三区久久精品| 亚洲精选在线观看| 欧美日韩综合视频网址| 亚洲每日更新| 亚洲欧美国产不卡| 国产精品高精视频免费| 久久久久综合网| 欧美理论电影在线播放| 久久精品青青大伊人av| 欧美国产精品久久| 久久国产精品久久国产精品| 麻豆成人91精品二区三区| 亚洲欧美第一页| 免费中文日韩| 一区二区三区色| 久久色中文字幕| 亚洲人成在线观看网站高清| 久久久久久久精| 国产欧美日韩另类一区| 日韩天堂在线视频| 亚洲精品一区二区三区福利| 久久成人18免费观看| 欧美一级在线视频| 欧美三级第一页| 一区二区欧美视频| 亚洲尤物精选| 亚洲国产精品一区二区久| 美女主播精品视频一二三四| 欧美一区日本一区韩国一区| 亚洲视频免费在线| 欧美日本乱大交xxxxx| 亚洲精品美女久久久久| 亚洲福利小视频| 欧美国产日韩精品| 亚洲国产岛国毛片在线| 亚洲电影免费观看高清完整版在线| 欧美一级久久久| 老司机aⅴ在线精品导航| 亚洲精品系列| 麻豆精品网站| 一区二区三区回区在观看免费视频| 99精品视频网| 欧美亚洲视频| 在线看一区二区| 欧美精品日韩三级| 性色av一区二区怡红| 欧美福利一区二区| 亚洲一区二区三区777| 国产欧美va欧美不卡在线| 欧美二区在线看| 欧美成人第一页| 免费不卡中文字幕视频| 欧美不卡福利| 久久亚裔精品欧美| 国产精品一区视频网站| 欧美一区免费| 亚洲精一区二区三区| 久久夜精品va视频免费观看| 亚洲美女在线一区| 国产午夜亚洲精品羞羞网站| 亚洲自拍偷拍麻豆| 欧美一区亚洲二区| 日韩一级成人av| 国产一区日韩二区欧美三区| 欧美精品一区在线| 久久av红桃一区二区小说| 一本色道久久综合亚洲精品婷婷 | 亚洲欧美日韩国产中文| 欧美国产日本在线| 久久久久国产精品厨房| 亚洲一区二区三区涩| 亚洲电影在线看| 在线精品国精品国产尤物884a| 欧美mv日韩mv国产网站app| 欧美综合激情网| 午夜精品久久久久久久久| 午夜精品一区二区三区四区| 日韩视频中文字幕| 妖精成人www高清在线观看| 久久精品99无色码中文字幕| 欧美一区二区国产| 亚洲精品社区| 国产精品色婷婷久久58| 国产欧美一区二区三区久久 | 欧美激情中文字幕乱码免费| 欧美激情第1页| 欧美日韩一区在线| 国产区精品视频| 在线观看欧美激情| 亚洲国产日韩美| 亚洲精品三级| 欧美在线综合视频| 久久亚洲精品一区二区| 亚洲电影第三页| 宅男噜噜噜66一区二区66| 亚洲一区自拍| 欧美精品免费观看二区| 国产精品亚洲人在线观看| 亚洲国产精品一区二区www| 一区二区三区黄色| 久久综合久久久久88| 夜夜嗨av一区二区三区免费区| 久久久久久久999精品视频| 欧美精品一区二区三区蜜桃| 国内精品久久久久国产盗摄免费观看完整版 | 亚洲狼人综合| 久久久精品性| 黄色成人小视频| 女生裸体视频一区二区三区| 久久国产主播| 久久精品2019中文字幕| 美女主播一区| 国产精品免费在线| 亚洲一区二区三区中文字幕| 亚洲黄色天堂| 欧美极品aⅴ影院| 国产精品你懂的在线| 久久久久久午夜| 欧美成人精品1314www| 亚洲欧洲在线视频| 日韩视频在线一区二区三区| 欧美人在线观看| 欧美一区亚洲二区| 久久国产精品99精品国产| 在线欧美日韩国产| 男同欧美伦乱| 国产精品xxx在线观看www| 午夜精品久久久久| 久久视频在线视频| 亚洲天堂成人在线视频| 亚洲一区二区少妇| 亚洲激情电影在线| 亚洲天堂第二页| 亚洲黄色成人久久久| 亚洲一区亚洲| 日韩亚洲一区在线播放| 欧美一区二区日韩一区二区| 亚洲欧洲一级| 久久精品在线观看| 亚洲综合色噜噜狠狠| 久久美女艺术照精彩视频福利播放| 91久久精品一区| 久久经典综合| 欧美一二区视频| 欧美日韩一区二区三区四区五区| 久久视频精品在线| 国产精品三上| 亚洲欧美日韩精品综合在线观看 | 欧美日韩免费一区二区三区| 欧美亚洲一区二区三区| 国产精品magnet| 亚洲精品免费在线| 加勒比av一区二区| 欧美一区二区播放| 久久免费视频在线| 狠狠爱综合网| 欧美freesex8一10精品| 欧美jizzhd精品欧美喷水| 黄色成人av| 久久久久国产精品一区| 欧美高清视频一区| 亚洲精品国精品久久99热| 欧美日韩精品免费观看视频完整| 亚洲激情在线| 亚洲欧美综合v| 精品99一区二区三区| 欧美日韩ab| 欧美一区二区三区四区在线观看| 久久免费国产精品1| 亚洲黄一区二区三区| 国产精品久久久久久久久| 午夜一区不卡| 日韩一区二区精品| 久久精品国产第一区二区三区| 亚洲区国产区| 国产一级揄自揄精品视频| 久久一区二区三区四区五区| 99re成人精品视频| 欧美高清视频一二三区| 亚洲裸体在线观看| 精品动漫3d一区二区三区免费版| 欧美精品久久一区二区| 久久黄色影院| 香蕉成人久久| 这里是久久伊人| 一区二区三区www| 一区二区三区欧美亚洲| 午夜精品免费| 一区二区日韩精品| 一区二区欧美国产|