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 ...
随机推荐
- Android应用基础学习记录
01_前言 前言,了解了Android的情况.这里也介绍一下本文.本文是记录学习Android应用程序开发过程,视频中使用的Android2.2版本号,我以4.2版本号为基础,找出当中的差异并记录下来 ...
- 网络编程-获取ip-解析ip
import java.net.InetAddress; import java.net.UnknownHostException; /** * 查询ip地址 * * @author chengluc ...
- YTU 2438: 三人三鬼
2438: 三人三鬼 时间限制: 1 Sec 内存限制: 128 MB 提交: 35 解决: 9 题目描述 目标是将东岸的3人3鬼通过一只小船转移到西岸,希望以尽可能少的摆渡次数. 船的容量有限, ...
- RabbitMQ(三)RabbitMQ消息过期时间(TTL)
在RabbitMQ(二)AMQP协议mandatory和immediate标志位区别中我们提到,在RabbitMQ3.0以后的版本里,去掉了immediate参数支持,要实现类似的确认功能要使用TTL ...
- hta+vbs+js+div+css (javascript是原生态的)
talbe是javascript动态生成的,根据你的sql语句来的,分页是vbs用数组来造的轮子,vbs这脚本虽然强大,却没有返回数据集的东东,数组来做简单的分页还是比较简单的,批量跟新呢?是上传ex ...
- Morris Traversal方法遍历二叉树(非递归,不用栈,O(1)空间)——无非是在传统遍历过程中修改叶子结点加入后继结点信息(传统是stack记录),然后再删除恢复
先看看线索二叉树 n个结点的二叉链表中含有n+1(2n-(n-1)=n+1)个空指针域.利用二叉链表中的空指针域,存放指向结点在某种遍历次序下的前驱和后继结点的指针(这种附加的指针称为"线索 ...
- I.MX6 MAC Address 导致的系统崩溃
/**************************************************************************** * I.MX6 MAC Address 导致 ...
- springmvc处理ajax跨域
解决跨域问题:在web.xml中配置corsFilter mvc.xml 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 <!- ...
- Pycharm安装及第一次使用导航
Pycharm:Pycharm是一种Python IDE,带有一整套可以帮助用户在使用Python语言开发时提高其效率的工具,比如调试.语法高亮.Project管理.代码跳转.智能提示.自动完成.单元 ...
- 解题报告:hdu 1073 Online Judge
题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=1073 Problem Description Ignatius is building an Onli ...