模板化类中的静态const成员初始化

时间:2010-07-22 08:31:52

标签: c++ static const visual-c++-2010

我有关于'static const'成员初始化的问题。在模板化的类中,我定义了一个const成员并在类之外初始化它 当我包含.h文件,其中该类在多个.cpp文件中实现时,我得到 LNK2005错误(我正在使用VS2010),该错误表示该常量已经定义

// List.hpp
template <class T>
class List {
    static const double TRIM_THRESHOLD;
};

template <class T>
const double List<T>::TRIM_THRESHOLD = 0.8;

我尝试将成员初始化放在.cpp文件中,但后来我得到一个链接器错误,说根本没有定义该常量。如果列表没有模板化,我将初始化放在.cpp文件中,一切都很好 这种情况有什么解决方案吗?我已经在文件周围有#ifdef / define子句,这绝对不是解决方案。

1 个答案:

答案 0 :(得分:7)

您应该在源文件中定义常量而不是标题(因此它只定义一次),因为这是您需要保留在标题中的模板(并且所有实例具有相同的值)您可以使用公共基类。

class ListBase {
protected:
    ListBase() {} // use only as base 
    ~ListBase() { } // prevent deletion from outside
    static const double TRIM_THRESHOLD;    
};

template <class T>
class List : ListBase {  
};

// in source file
double ListBase::TRIM_THRESHOLD = 0.8;

另一个选择是将它作为静态函数:

    static double trim_threashold() { return 0.8; }

编辑:如果您的编译器支持C ++ 11,则可以将static方法设为constexpr function,以便它具有直接使用该值的所有优化机会。