01 2022 档案
C++ std::Recursive_mutex 支持 “对同一互斥量进行嵌套加锁”
摘要:使用场景:一个类的不同成员函数之间,存在相互调用的情况, 如果这样的成员函数作为线程的入口函数时,就会出现在成员函数 func1()中对某个互斥量上锁,并且, func1()中调用了成员函数 func2() ,实际上 func2()为了保护成员数据,func2()内部也对同一个互斥量上锁。 在我们对
阅读全文
采用C++17新标准 “共享锁”和“独占锁”更低消耗更好性能地保护不常更新的共享数据
摘要:用到的标准库: std::shared_lock<>、 std::shared_mutex、 std::lock_guard<>。 另外还有 std::shared_timed_mutex(此处不讲)。 分析:对于保护不常更新的共享数据, 因为写只是很偶然的发生,更频繁的是读取。如果不区分 “读者”
阅读全文
std::once_flag结构体和std::call_once()函数搭配来处理条件竞争
摘要:C++标准委员会也认为条件竞争的处理很重要。所以,C++标准库提供了 std::once_flag结构体 和 std::call_once() 函数,来处理条件竞争(这种情况的条件竞争:臭名昭著的双重检查锁模式)。 比起锁住互斥量并显示的检查指针,只需要使用 std::call_once() 就可以
阅读全文
双重检查锁--声名狼藉, 臭名昭著
摘要:双重检查锁模式,是经常听到和用到的方式,既保护了数据的初始化过程,也避免了每次访问时,多个线程要序列化的检查锁问题。 不过,又有观点说,双重检查锁模式是声名狼藉,是臭名昭著的。下面我们通过例子来分析论证。直接贴代码,附上执行结果,我们先看效果,再做分析。 1 xxx.h 2 3 #include <
阅读全文