C++11并发之std::mutex
1、 头文件。
- std::mutex,最基本的 Mutex 类。
- std::recursive_mutex,递归 Mutex 类。
- std::time_mutex,定时 Mutex 类。
- std::recursive_timed_mutex,定时递归 Mutex 类。
- std::lock_guard,与 Mutex RAII 相关,方便线程对互斥量上锁。
- std::unique_lock,与 Mutex RAII 相关,方便线程对互斥量上锁,但提供了更好的上锁和解锁控制。
- std::once_flag
- std::adopt_lock_t
- std::defer_lock_t
- std::try_to_lock_t
函数
- std::try_lock,尝试同时对多个互斥量上锁。
- std::lock,可以同时对多个互斥量上锁。
- std::call_once,如果多个线程需要同时调用某个函数,call_once 可以保证多个线程对该函数只调用一次。
2、std::mutex。
std::mutex 的成员函数
#include //std::cout#include //std::thread#include //std::mutex#include //std::atomicusing namespace std;atomic_int counter{ 0 }; //原子变量mutex g_mtx; //互斥量void fun(){for (int i = 0; i <</span> 1000000; ++i){if (g_mtx.try_lock()) //尝试是否可以加锁{++counter;g_mtx.unlock(); //解锁}}}int main(){thread threads[10];for (int i = 0; i <</span> 10; ++i){threads[i] = thread(fun);}for (auto & th : threads){th.join();}cout << "counter=" << counter << endl;system("pause");return 0;}运行结果:counter=1342244
3、std::recursive_mutex。
#include //std::cout#include //std::thread#include //std::mutexusing namespace std;mutex g_mutex;void threadfun1(){cout << "enter threadfun1" << endl;lock_guard lock(g_mutex);cout << "execute threadfun1" << endl;}void threadfun2(){cout << "enter threadfun2" << endl;lock_guard lock(g_mutex);threadfun1();cout << "execute threadfun2" << endl;}int main(){threadfun2(); //死锁//Unhandled exception at 0x758BC42D in Project2.exe: Microsoft C++ exception: std::system_error at memory location 0x0015F140.return 0;}运行结果:enter threadfun2enter threadfun1//就会产生死锁
#include //std::cout#include //std::thread#include //std::mutexusing namespace std;recursive_mutex g_rec_mutex;void threadfun1(){cout << "enter threadfun1" << endl;lock_guard lock(g_rec_mutex);cout << "execute threadfun1" << endl;}void threadfun2(){cout << "enter threadfun2" << endl;lock_guard lock(g_rec_mutex);threadfun1();cout << "execute threadfun2" << endl;}int main(){threadfun2(); //利用递归式互斥量来避免这个问题return 0;}运行结果:enter threadfun2enter threadfun1execute threadfun1execute threadfun2
4、std::time_mutex。
#include //std::cout#include //std::thread#include //std::mutexusing namespace std;std::timed_mutex g_t_mtx;void fun(){while (!g_t_mtx.try_lock_for(std::chrono::milliseconds(200))){cout << "-";}this_thread::sleep_for(std::chrono::milliseconds(1000));cout << "*" << endl;g_t_mtx.unlock();}int main(){std::thread threads[10];for (int i = 0; i <</span> 10; i++){threads[i] = std::thread(fun);}for (auto & th : threads){th.join();}return 0;}运行结果:------------------------------------*----------------------------------------*-----------------------------------*------------------------------*-------------------------*--------------------*---------------*----------*-----**
5、std::lock_guard 与 std::unique_lock。
#include //std::cout#include //std::thread#include //std::mutex#include //std::atomicusing namespace std;mutex g_mtx1;atomic_int num1{ 0 };void fun1(){for (int i = 0; i <</span> 10000000; i++){unique_lock ulk(g_mtx1);num1++;}}mutex g_mtx2;atomic_int num2{ 0 };void fun2(){for (int i = 0; i <</span> 10000000; i++){lock_guard lckg(g_mtx2);num2++;}}int main(){thread th1(fun1);thread th2(fun1);th1.join();th2.join();cout << "num1=" << num1 << endl;thread th3(fun2);thread th4(fun2);th3.join();th4.join();cout << "num2=" << num2 << endl;return 0;}运行结果:num1=20000000num2=20000000
C++11并发之std::mutex的更多相关文章
- C++11并发之std::thread<转>
最近技术上没什么大的收获,也是悲催的路过~ 搞一点新东西压压惊吧! C++11并发之std::thread 知识链接: C++11 并发之std::mutex C++11 并发之std::atomic ...
- c++11并发之std::thread
知识链接: https://www.cnblogs.com/lidabo/p/7852033.html 构造函数如下: ) thread() noexcept; initialization() te ...
- C++11并发——多线程std::mutex (二)
https://www.cnblogs.com/haippy/p/3237213.html Mutex 又称互斥量,C++ 11中与 Mutex 相关的类(包括锁类型)和函数都声明在 <mute ...
- C++11 并发之std::thread std::mutex
https://www.cnblogs.com/whlook/p/6573659.html (https://www.cnblogs.com/lidabo/p/7852033.html) C++:线程 ...
- C++11 并发指南三(std::mutex 详解)
上一篇<C++11 并发指南二(std::thread 详解)>中主要讲到了 std::thread 的一些用法,并给出了两个小例子,本文将介绍 std::mutex 的用法. Mutex ...
- C++11 并发指南三(std::mutex 详解)(转)
转自:http://www.cnblogs.com/haippy/p/3237213.html 上一篇<C++11 并发指南二(std::thread 详解)>中主要讲到了 std::th ...
- 【C/C++开发】C++11 并发指南三(std::mutex 详解)
本系列文章主要介绍 C++11 并发编程,计划分为 9 章介绍 C++11 的并发和多线程编程,分别如下: C++11 并发指南一(C++11 多线程初探)(本章计划 1-2 篇,已完成 1 篇) C ...
- C++11:基于std::queue和std::mutex构建一个线程安全的队列
C++11:基于std::queue和std::mutex构建一个线程安全的队列 C++中的模板std::queue提供了一个队列容器,但这个容器并不是线程安全的,如果在多线程环境下使用队列,它是不能 ...
- C++11 并发指南------std::thread 详解
参考: https://github.com/forhappy/Cplusplus-Concurrency-In-Practice/blob/master/zh/chapter3-Thread/Int ...
随机推荐
- c# 32位机和64位机 读取Excel内容到DataSet
// ----------------------32位机 //注释说明 //ExclePath 为Excel路径 批号 是指Excel文件中某一列必填项 public static DataSet ...
- YTU 2980: 几点了
2980: 几点了 时间限制: 1 Sec 内存限制: 128 MB 提交: 37 解决: 9 题目描述 现有一个Time类可以用来记录时间,请输出Time记录的时间加上s秒后的时间. 只需提交补 ...
- Where Are You Standing?
/*********************************************************************** * Where Are You Standing? * ...
- [Codeforces 1011E] Border
[题目链接] https://codeforces.com/contest/1011/problem/E [算法] 裴蜀定理 : 设为n个整数,d是它们的最大公约数,那么存在整数 使得 显然 , ...
- Create
BOOL Create(LPCTSTR lpszClassName,LPCTSTR lpszWindowName, DWORD dwStyle,const RECT& rect,CWnd* p ...
- Tomcat闪退的解决办法
1 首先考虑的是端口占用 2 现在讲的是这一种方法 (1)找到解压缩的文件的bin目录 找到startup.bat 记事本打开 开头加上两句话 SET JAVA_HOME=C:\Program Fil ...
- MongoDB安全事件的防范与反思
此文已由作者温正湖授权网易云社区发布. 欢迎访问网易云社区,了解更多网易技术产品运营经验. 近段时间来,全球范围内数以万计的MongoDB实例被攻击,作为旨在为用户提供最优MongoDB云服务的网易蜂 ...
- HDU1452:Happy 2004(积性函数)(因子和)
题意 给出\(x\),求\(2004^x\)的所有因子和 分析 \(2004=2*2*3*167\) 则\(2004^x\)=\(2^{2x}*3^x*167^x\) s[\(2004^x\)]=s[ ...
- 使用python计算softmax函数
softmax计算公式: Softmax是机器学习中一个非常重要的工具,他可以兼容 logistics 算法.可以独立作为机器学习的模型进行建模训练.还可 ...
- nginx 配置tp3.2
server { listen 80; server_name 域名; #charset koi8-r; #access_log /var/log/nginx/host.access.log main ...