C++ 类模板的静态私有内部类如何初始化? 5
搞了一个通宵了,百度过很多资料,始终解决不了这个问题。令我开始对C++的繁琐感到厌倦了。为了编译通过这么一个小问题,折腾这么长时间,真心觉得这种语言繁琐,刻板,效率低,过...
搞了一个通宵了,百度过很多资料,始终解决不了这个问题。令我开始对C++的繁琐感到厌倦了。为了编译通过这么一个小问题,折腾这么长时间,真心觉得这种语言繁琐,刻板,效率低,过时了,让我这个6年的C++粉开始有点失望……
#ifndef __SINGLETON__H__
#define __SINGLETON__H__
template <typename T>
class Singleton
{
public:
static T* GetInstance()
{
return m_pInstance;
}
protected:
Singleton() {}
~Singleton() {}
private:
Singleton(const Singleton<T> &);
Singleton& operator = (const Singleton<T> &);
static T* m_pInstance;
class Worker // 这里在类模板中定义了一个内部类
{
public:
Worker()
{
i = 0;
if ( !m_pInstance )
{m_pInstance = new T();printf("ccc\n");}
}
~Worker()
{
if ( m_pInstance )
{delete m_pInstance;printf("ddd\n");}
}
int i;
};
static Worker worker; // 静态内部类成员,私有的。为了在类模板实例创建时自动调用此静态内部类的构造函数,销毁时自动调用此静态内部类的析构函数
};
template <typename T> T* Singleton<T>::m_pInstance = NULL; // 这句编译通过
template <typename T> Singleton<T>::Worker Singleton<T>::worker; // 就是这句编译不通过,纠结了一晚上了,浪费了许多时间,不知道该怎么写,求大神们指教。
#define SINGLETON_INIT(Type) friend Type* Singleton<Type>::GetInstance(); private: Type(); ~Type()
#endif
错误输出:
警告 1 warning C4346: “Singleton::Worker”: 依赖名称不是类型
错误 2 error C2143: 语法错误 : 缺少“;”(在“Singleton::worker”的前面)
错误 3 error C4430: 缺少类型说明符 - 假定为 int。注意: C++ 不支持默认 int 展开
#ifndef __SINGLETON__H__
#define __SINGLETON__H__
template <typename T>
class Singleton
{
public:
static T* GetInstance()
{
return m_pInstance;
}
protected:
Singleton() {}
~Singleton() {}
private:
Singleton(const Singleton<T> &);
Singleton& operator = (const Singleton<T> &);
static T* m_pInstance;
class Worker // 这里在类模板中定义了一个内部类
{
public:
Worker()
{
i = 0;
if ( !m_pInstance )
{m_pInstance = new T();printf("ccc\n");}
}
~Worker()
{
if ( m_pInstance )
{delete m_pInstance;printf("ddd\n");}
}
int i;
};
static Worker worker; // 静态内部类成员,私有的。为了在类模板实例创建时自动调用此静态内部类的构造函数,销毁时自动调用此静态内部类的析构函数
};
template <typename T> T* Singleton<T>::m_pInstance = NULL; // 这句编译通过
template <typename T> Singleton<T>::Worker Singleton<T>::worker; // 就是这句编译不通过,纠结了一晚上了,浪费了许多时间,不知道该怎么写,求大神们指教。
#define SINGLETON_INIT(Type) friend Type* Singleton<Type>::GetInstance(); private: Type(); ~Type()
#endif
错误输出:
警告 1 warning C4346: “Singleton::Worker”: 依赖名称不是类型
错误 2 error C2143: 语法错误 : 缺少“;”(在“Singleton::worker”的前面)
错误 3 error C4430: 缺少类型说明符 - 假定为 int。注意: C++ 不支持默认 int 展开
1个回答
展开全部
template <typename T> Singleton<T>::Worker Singleton<T>::worker;你这句话是多余的。应该是在模板实例化的时候生成的Class里就含有一个Worker的实例了(因为你是静态的),这样再用这个类生成实例的时候也就自然会在各个实例中共享这个worker instance。
追问
可是C++规定,静态类成员必须在类内声明,类外再定义一次。如果把这句话删掉,同样编译不通过
追答
Singleton::Worker Singleton::worker;这样就可以了,也就是说你先要模板实例化
Storm代理
2023-08-29 广告
2023-08-29 广告
"StormProxies是全球大数据IP资源服务商,其住宅代理网络由真实的家庭住宅IP组成,可为企业或个人提供满足各种场景的代理产品。点击免费测试(注册即送1G流量)StormProxies有哪些优势?1、IP+端口提取形式,不限带宽,I...
点击进入详情页
本回答由Storm代理提供
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询