模板链接器错误

时间:2017-11-16 20:54:05

标签: c++ templates explicit-instantiation

我问你的帮助,因为我正在使用模板,似乎我误解了一些东西。

这是我的代码:

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
你知道吗?我做的事情与我链接的文章不一样吗?

提前致谢。

3 个答案:

答案 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)