我实现了一个模板单例类以及静态成员定义:
template <typename T> class SingletonT
{
public:
static T *GetInstance()
{
if (!s_instance)
{
s_instance = new T;
}
return s_instance;
}
private:
static T *s_instance;
};
template <typename T> T *SingletonT<T>::s_instance = 0;
它编译良好并且工作正常。
现在,我正在尝试创建一个将使用自定义函数而不是运算符 new
的单例:
template <typename T, T *(*f)()> class PolymorphSingletonT
{
public:
static T *GetInstance()
{
if (!s_instance)
{
s_instance = f();
}
return s_instance;
}
private:
static T *s_instance;
};
template <typename T, T *(*f)()> T *PolymorphSingletonT<T, T *(*f)()>::s_instance = 0;
我在最后一行收到编译错误,显示错误 C2146:语法错误:标识符“f”之前缺少“)”
我使用MSVC2005编译器。
更新 现在我最终采用了仿函数方法:
template <typename T, typename F> class PolymorphSingletonT
{
public:
static T *GetInstance()
{
if (!s_instance)
{
s_instance = F::Create();
}
return s_instance;
}
private:
static T *s_instance;
};
template <typename T, typename F> T *PolymorphSingletonT<T, F>::s_instance = 0;
但是,它迫使我用仿函数包装我的创建函数。它只添加了几行代码并且工作得很好,但无论如何我仍然有兴趣在没有仿函数的情况下获得它。
最佳答案
最后一行应该是:
template <typename T, T *(*f)()> T *PolymorphSingletonT<T,f>::s_instance = 0;
不要重复类型签名,使用您指定的名称。
关于C++ 自定义单例,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/13543445/