关于c++单例模式的线程安全实现
学过java设计模式的都知道,在java中实现线程安全的单例模式有两种方法,
第一种是通过使用静态的局部变量的方法来产生单例,也就是类似于本文开头给出的实现,
另一种方法是通过线程互斥的方法在多线程中产生单例,也就是在getInstance的方法前加synchronized关键字
在c++中也可以通过这两种相似方法来实现,但是在c++中,使用静态局部变量的方法来产生单例,需要注意的是,C++0X以后,要求编译器保证内部静态变量的线程安全性,因此在支持c++0X的编译器中这种方法可以产生线程安全的单例模式,然而在不支持c++0X的编译器中,这种方法无法得到保证。
以下是关于c++单例模式的线程安全实现示例代码:
#include <boost/utility.hpp>
class Singleton:boost::noncopyable
{
private:
Singleton()
{
}
public:
static Singleton* getInstance()
{
lock() //在支持c++0x的编译器中可以不需要,在不支持c++0x的编译器中,最好利用相关多线程的互斥来实现
static Singleton instance;
unlock();
return &instance;
}
};