我问你的帮助,因为我正在使用模板,似乎我误解了一些东西。
这是我的代码:
arbre.h
template<typename T>
class Arbre;
template<typename T>
class Noeud
{
friend class Arbre<T>;
public :
Noeud();
~Noeud();
T get_info()const;
private :
T info;
Noeud<T> *fg, *fd;
};
template<typename T>
class Arbre
{
public :
//Constructors-------------------------------------------------------------
Arbre();
/*
other function definitions
*/
}
arbre.tpp
#include "arbre.h"
template <typename T>
Noeud<T>::Noeud(){
fg = fd = 0;
}
template <typename T>
Noeud<T>::~Noeud(){
}
template <typename T>
T Noeud<T>::get_info()const{
return info;
}
template <typename T>
Arbre<T>::Arbre(){
racine = 0;
}
/*
other function implementations...
*/
main.cpp 包含“arbre.h”并创建一个如下对象:
Arbre<int> a;
因此,请遵循有关显式实例化的文章:http://www.cplusplus.com/forum/articles/14272/
我在arbre.tpp末尾添加了这两行:
template class Noeud<int>;
template class Arbre<int>;
这样链接器就可以在arbre.o中编译我的对象的int版本的代码,所以我可以将实现(arbre.tpp)与头文件(arbre.h)分开。我的代码使用了隐式实例化(在header.h的末尾包含了arbre.tpp),但我想让它们分开。
我想知道为什么链接会失败:
g++ -o main.o -c main.cpp -Wall -g -std=c++11
g++ -o arbre.o -c arbre.tpp -Wall -g -std=c++11
g++: warning: arbre.tpp: linker input file unused because linking not done
g++ -o arbre.out main.o arbre.o
g++: error: arbre.o: No such file or directory
Makefile:9: recipe for target 'arbre.out' failed
make: *** [arbre.out] Error 1
你知道吗?我做的事情与我链接的文章不一样吗?
提前致谢。
答案 0 :(得分:3)
显式实例化定义是不够的。一般来说,编译器应该假定主要模板定义是它看到的所有内容。所以,那些专业化依赖于未定义的成员。
但是,有一个明确的实例化声明的概念。它告诉编译器在其他地方查找模板定义。只需在标题的底部添加这两个:
extern template class Noeud<int>;
extern template class Arbre<int>;
答案 1 :(得分:0)
由于您使用的是非标准扩展.tpp
,因此您可能希望告诉编译器您正在使用C ++代码g++ -x c++
。
答案 2 :(得分:0)
带模板定义的文件无法单独编译和链接。试试以下内容: -
在main.ccp文件的顶部包含&#34; arbre.tpp&#34;像头文件一样,只编译main.cpp文件并生成exe。
在你的main.cpp
中#include"arbre.tpp"
$g++ main.cpp -o test
$./test (to run the application)