关于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;
}
};
C++单例模式线程安全
本文介绍C++中实现线程安全的单例模式的两种方法:使用静态局部变量及线程互斥。在支持C++0X的编译器中,静态局部变量方法能确保线程安全。
1261

被折叠的 条评论
为什么被折叠?



