单例设计模式的实现有关问题。代码如下
单例设计模式的实现问题。代码如下:
是不是上面的代码有问题,问了许多了都说写的有问题,哪为大大帮我修改下。。。我自己觉得挺好,没看出问题所在
------解决方案--------------------
Singleton::~Singleton()
{
if(instance != NULL)
{
delete instance;
instance = NULL;
}
}
//初始化静态成员
Singleton* Singleton::instance=NULL;
Singleton* Singleton::GetInstance()
{
if(instance == NULL)
instance = new Singleton();
return instance;
}
- C/C++ code
#include <iostream>
using namespace std;
//单例类的C++实现
class Singleton
{
private:
Singleton();//注意:构造方法私有
virtual ~Singleton();
static Singleton* instance;//惟一实例
int var;//成员变量(用于测试)
public:
static Singleton* GetInstance();//工厂方法(用来获得实例)
int getVar();//获得var的值
void setVar(int);//设置var的值
};
//构造方法实现
Singleton::Singleton()
{
this->var = 20;
cout<<"Singleton Constructor"<<endl;
}
Singleton::~Singleton()
{
delete instance;
}
//初始化静态成员
Singleton* Singleton::instance=new Singleton();
Singleton* Singleton::GetInstance()
{
return instance;
}
//seter && getter含数
int Singleton::getVar()
{
return this->var;
}
void Singleton::setVar(int var)
{
this->var = var;
}
//main
int main(int argc, char* argv[])
{
Singleton *ton1 = Singleton::GetInstance();
Singleton *ton2 = Singleton::GetInstance();
cout<<"ton1 var = "<<ton1->getVar()<<endl;
ton1->setVar(150);
cout<<"ton2 var = "<<ton2->getVar()<<endl;
return 0;
}
是不是上面的代码有问题,问了许多了都说写的有问题,哪为大大帮我修改下。。。我自己觉得挺好,没看出问题所在
------解决方案--------------------
Singleton::~Singleton()
{
if(instance != NULL)
{
delete instance;
instance = NULL;
}
}
//初始化静态成员
Singleton* Singleton::instance=NULL;
Singleton* Singleton::GetInstance()
{
if(instance == NULL)
instance = new Singleton();
return instance;
}