C++11标准库 互斥锁 <mutex> 梳理
目录[*]
[*]std::call_once函数
[*]例程:使用call_once实现的单例模式
[*]std::mutex类 -- 独占互斥锁
[*]成员函数
[*]std::recursive_mutex类 -- 递归互斥锁
[*]使用注意:
[*]描述:
[*]std::timed_mutex类 -- 超时互斥锁
[*]描述:
[*]成员函数:
[*]std::recursive_timed_mutex类
[*]std::lock_guard模板类
[*]函数原型:
[*]std::unique_lock模板类
[*]成员方法
std::call_once函数
多线程操作过程中,std::call_once()内部的回调函数只会被执行一次
在某些特定情况下,某些函数只能在多线程环境下调用一次,比如:要初始化某个对象,而这个对象只能被初始化一次,就可以使用std::call_once()来保证函数在多线程环境下只能被调用一次。使用call_once()的时候,需要一个once_flag作为call_once()的传入参数.
函数原型:
// 定义于头文件 <mutex>,属于std
template< class Callable, class... Args >
void call_once( std::once_flag& flag, Callable&& f, Args&&... args );
[*]flag:once_flag类型的对象,要保证这个对象能够被多个线程同时访问到
[*]f:回调函数,可以传递一个有名函数地址,也可以指定一个匿名函数
[*]args:作为实参传递给回调函数
例程:使用call_once实现的单例模式
#include#include#includestd::once_flag g_flag;class Singleton {public: Singleton(const Singleton& s) = delete; Singleton& operator=(const Singleton&s) = delete; static Singleton* GetInstance() { std::call_once(g_flag,[](){ std::cout
页:
[1]