单一定义规则规定程序应该包含每个非内联函数的一个定义。对于模板类的成员,这对我来说并不完全清楚:
///////////
// Tfoo.h
template<typename T> class A {
void foo(){}
};
///////////
// intfoo.h
#include <Tfoo.h>
template<> class Foo<int> {
void foo(); // declaration only
};
/*inline*/ void Foo<int>::foo(){} // definition
///////////
// X.cpp
#include <intfoo.h>
///////////
// Y.cpp
#include <intfoo.h>
在这种情况下,clientX.obj 和 clientY.obj 都有一个 .obj 的定义Foo<int>::foo
。链接器抱怨这个符号被定义了不止一次:
Y.obj : error LNK2005: "private: void __thiscall Foo<int>::foo(void)"
(?foo@?$Foo@H@@AAEXXZ) already defined in X.obj
当我inline
添加 的定义时Foo<int>::foo()
,一切顺利,链接器很高兴。此外,当我在单独的编译单元(例如 intfoo.cpp)中定义它们时。
(注意:此解决方案在https://stackoverflow.com/a/1481796/6610中提出)
可能是一个误解,但模板类的成员函数不是总是“内联”的吗?这里的规则是什么?