在 C 和 C++ 中,函数、ADT 和类的一个非常常见的编码模式是:
- 带有(类的函数)声明的头 .h 文件。
- 带有实际代码的实现 .cpp 文件。
这些被编译成一个单独的对象(共享或不共享)。其他代码,使用声明的实体(我们称之为'foo'),包括 foo.h 文件,单独编译,然后链接到 foo.o 。
但是,对于模板化的 foo,这是不可能的:如果不指定所需的实例化类型, foo.o 是无用的。每个人似乎都在做的是将实现代码(通常是 foo.cpp)包含在与用户代码相同的翻译单元中。
我希望能够避免这种情况,使用一些不需要包括 foo.cpp 的机制。理想情况下,这应该有效:
主.cpp:
#include "foo.h"
int main() {
foo<int>();
}
富.h:
template<typename T> void foo();
foo.cpp:
template<typename T> void foo() {
// implementation here
}
为此,我想我需要某种巧妙的习惯用法,可能涉及我的构建机制,而不仅仅是源文件和头文件,因此我不需要包含实现代码,只需包含头文件。我在想可能是实现文件的一些内容,包括一些自动生成的标题,例如
template foo<int>();
这将解析它们缺少的实例的目标文件(即两次编译传递),或者可能解析源文件(调整编译器?启用一些辅助输出?);你能推荐这样一个成语吗?还是我没有考虑过的另一种选择?
注意:当然,重点在于 foo 模块 ( foo.h
, foo.cpp
) 的代码不“知道”需要哪些实例化,例如不知道是否main()
会使用foo<int>()
或foo<unsigned char>()
。