(1)
// Foo.h
template<typename T>
class Foo
{
public:
void f();
};
// Foo.cpp
#include <iostream>
#include "Foo.h"
template<typename T>
void Foo<T>::f()
{
std::cout << "Foo<T>::f()/n";
}
// main.cpp
#include "Foo.h"
int main()
{
Foo<int> x;
x.f();
}
如上组织,会编译出错。
而如果把Foo.h和Foo.cpp合并在一起,就不会出现编译错误了。
#include <iostream>
template<typename T>
class Foo
{
public:
void f();
};
template<typename T>
void Foo<T>::f()
{
std::cout << "Foo<T>::f()/n";
}
int main()
{
Foo<int> x;
x.f();
}
这是正确的。
为什么呢?
(2)由于现在还没有支持template分离编译的编译器(记得目前还没有),因此我们常见的temp

本文讨论了C++中模板类的头文件和源文件分开编译时遇到的问题。当模板类的实现与声明分开时,会导致编译错误。原因在于模板的实例化发生在每个包含它的编译单元中,导致重复定义。解决方法是将模板类的实现放在头文件中,或者使用某些编译器的特定处理方式。同时,文章指出,虽然不推荐将模板类的实现分开编译,但Boost库提供了一些处理这个问题的实践方案。
378

被折叠的 条评论
为什么被折叠?



