头文件中模板专门化的静态变量初始化
Static variable initialization for template specialization in header
有一个c++头库,但在某些时候已经添加了模板专门化(就在头中)。一切都很好,直到需要链接使用这个库的两个文件。当然,有一个链接错误。问题是库的类使用静态变量。它们在头文件中直接为模板特化而初始化。
问题是:是否有可能在头文件中初始化模板专门化的静态变量并以某种方式避免链接错误?(类似于为模板类方法专门化添加内联关键字,有类似的链接问题)
欢迎任何想法(包括肮脏的把戏等)。
一些代码示例:
lib.hpp:
template <typename T>
struct LibClass
{
static const int variable;
static void f()
{
// use variable
}
};
typedef LibClass<int> IntLibClass;
template <> const int IntLibClass::variable = 0;
typedef LibClass<double> DoubleLibClass;
template <> const int DoubleLibClass::variable = 1;
A.cpp:
#include "lib.hpp"
void g()
{
IntLibClass a;
a.f();
}
B.cpp:
#include "lib.hpp"
void h()
{
DoubleLibClass b;
b.f();
}
int main()
{
h();
}
我想把A和B连在一起
g++ A.cpp B.cpp
只需将以下内容添加到项目的附加文件lib.cpp
:
#include "lib.hpp"
template <> const int IntLibClass::variable = 0;
template <> const int DoubleLibClass::variable = 1;
并以以下方式更改lib.hpp
文件(删除初始化):
typedef LibClass<int> IntLibClass;
template <> const int IntLibClass::variable;
typedef LibClass<double> DoubleLibClass;
template <> const int DoubleLibClass::variable;
正如Johannes Schaub - litb在注释中指出的那样,这个解决方案意味着在头文件中不初始化静态变量(正如问题中所要求的那样),因此变量值不能用于常量表达式(lib.cpp
文件之外)。
但是这个解决方案适用于问题中给出的代码片段
相关文章:
- 在 .h 文件中的类中声明静态变量和在.cpp文件中声明"global"变量有什么区别
- 模板基类中的静态变量
- 类和静态变量
- 不同作用域中的静态变量和全局变量
- 静态变量声明和定义
- 是否可以依赖函数范围的静态变量来执行程序关闭期间调用的方法?
- 在类中继承静态变量?
- "local scope"中的 C++ 初始化静态变量
- 使用静态变量的递归调用的不同输出
- 复制文件流C++静态变量
- 跨模板化函数编译的静态变量
- C++编译器是否优化了顺序静态变量读取?
- C++,每个循环初始化一个新的静态变量
- (为什么)我们可以在初始化中将非静态类成员分配给静态变量吗?
- 这些语句是否等效(静态变量、常量变量和泛型)
- 程序如何知道静态变量是否需要初始化?
- 类外的静态变量实例化
- 无法解析静态变量
- 函数局部静态变量:从性能角度来看的优点/缺点
- 访问从 CPP 文件到其他头文件的静态变量