#include<mutex>

包含四类锁:

1      std::mutex    最基本也是最常用的互斥类

2      std::recursive_mutex  同一线程内可递归(重入)的互斥类

3      std::timed_mutex 除具备mutex功能外,还提供了带时限请求锁定的能力

4      std::recursive_timed_mutex      同一线程内可递归(重入)的timed_mutex

锁的操作:

1、lock, try_lock, unlock

lock:

如果互斥量没有被锁住,则调用线程将该mutex锁住,直到调用线程调用unlock释放。

如果mutex已被其它线程lock,则调用线程将被阻塞,直到其它线程unlock该mutex。

如果当前mutex已经被调用者线程锁住,则std::mutex死锁,而recursive系列则成功返回。

try_lock:

如果互斥量没有被锁住,则调用线程将该mutex锁住(返回true),直到调用线程调用unlock释放。

如果mutex已被其它线程lock,则调用线程将失败,并返回false。

如果当前mutex已经被调用者线程锁住,则std::mutex死锁,而recursive系列则成功返回true。

  1. #include <iostream>
  2. #include <thread>
  3. #include <mutex>
  4.  
  5. void inc(std::mutex &mutex, int loop, int &counter) {
  6. for (int i = ; i < loop; i++) {
  7. mutex.lock();
  8. ++counter;
  9. mutex.unlock();
  10. }
  11. }
  12. int main() {
  13. std::thread threads[];
  14. std::mutex mutex;
  15. int counter = ;
  16.  
  17. for (std::thread &thr: threads) {
  18. thr = std::thread(inc, std::ref(mutex), , std::ref(counter));
  19. }
  20. for (std::thread &thr: threads) {
  21. thr.join();
  22. }
  23.  
  24. // 输出:5000,如果inc中调用的是try_lock,则此处可能会<5000
  25. std::cout << counter << std::endl;
  26.  
  27. return ;
  28. }
  29. //: g++ -std=c++11 main.cpp

参考 https://www.jianshu.com/p/96eac2d183b1

2、try_lock_for, try_lock_until

这两个函数仅用于timed系列的mutex(std::timed_mutex, std::recursive_timed_mutex),函数最多会等待指定的时间,如果仍未获得锁,则返回false。除超时设定外,这两个函数与try_lock行为一致。

  1. #include <iostream>
  2. #include <thread>
  3. #include <mutex>
  4. #include <chrono>
  5.  
  6. void run500ms(std::timed_mutex &mutex) {
  7. auto _500ms = std::chrono::milliseconds();
  8. if (mutex.try_lock_for(_500ms)) {
  9. std::cout << "获得了锁" << std::endl;
  10. } else {
  11. std::cout << "未获得锁" << std::endl;
  12. }
  13. }
  14. int main() {
  15. std::timed_mutex mutex;
  16.  
  17. mutex.lock();
  18. std::thread thread(run500ms, std::ref(mutex));
  19. thread.join();
  20. mutex.unlock();
  21.  
  22. return ;
  23. }
  24. //输出:未获得锁

参考 https://www.jianshu.com/p/96eac2d183b1

3、lock_guard、unique_lock、std::call_once、std::try_lock、std::lock(略)

c++11多线程---线程锁(mutex)的更多相关文章

  1. C++ 11 多线程--线程管理

    说到多线程编程,那么就不得不提并行和并发,多线程是实现并发(并行)的一种手段.并行是指两个或多个独立的操作同时进行.注意这里是同时进行,区别于并发,在一个时间段内执行多个操作.在单核时代,多个线程是并 ...

  2. Python多线程-线程锁

    多线程修改一份数据时需要用到线程锁,以防止数据修改出错 #-*- coding:utf-8 -*- __author__ = "MuT6 Sch01aR" import threa ...

  3. (转)C++ 11 多线程--线程管理

    说到多线程编程,那么就不得不提并行和并发,多线程是实现并发(并行)的一种手段.并行是指两个或多个独立的操作同时进行.注意这里是同时进行,区别于并发,在一个时间段内执行多个操作.在单核时代,多个线程是并 ...

  4. c++11多线程---线程入口函数

    1.普通函数(线程入口) #include <thread> #include <iostream> void hello(const char *name) { std::c ...

  5. c++11多线程---线程操作

    1.等待线程执行完成 join() 方法数会阻塞主线程直到目标线程调用完毕,即join会直接执行该子线程的函数体部分. 2.暂停线程(线程休眠) 使用std::this_thread::sleep_f ...

  6. Python GIL、线程锁、信号量及事件

    GIL是什么? GIL并不是Python的特性,它是在实现Python解析器(CPython)时所引入的一个概念.就好比C++是一套语言(语法)标准,但是可以用不同的编译器来编译成可执行代码.有名的编 ...

  7. Cocos2d-X多线程(2) 线程的互斥量std::mutex和线程锁

    多个线程同时访问共享资源时,经常会出现冲突等.为了避免这种情况的发生,可以使用互斥量,当一个线程锁住了互斥量后,其他线程必须等待这个互斥量解锁后才能访问它. thread提供了四种不同的互斥量: 1. ...

  8. iOS 多线程的简单理解(4) 线程锁的简单使用

    要用到多线程 ,就不得不考虑,线程之间的交互,线程是否安全 推荐一个原文链接 是关于 线程锁的基本使用的  http://blog.csdn.net/qq_30513483/article/detai ...

  9. iOS 多线程之线程锁Swift-Demo示例总结

    线程锁是什么 在前面的文章中总结过多线程,总结了多线程之后,线程锁也是必须要好好总结的东西,这篇文章构思的时候可能写的东西得许多,只能挤时间一点点的慢慢的总结了,知道了线程之后要了解线程锁就得先了解一 ...

随机推荐

  1. 第三篇 HTML 表单及表格

    表单及表格 表单,常用在登录.注册等地方,这也是一个最基本的.   我们就用登录,来学习什么是表单!   表单 form 标签,在某些好用的编辑工具,比如:WebStorm  你在上面写出form再按 ...

  2. shell脚本实战

    想写个脚本,发现都忘了,蛋疼,一边回忆一边查一边写,总算完成了,贴在下面: #!/bin/bash #Program: # This program can help you quickly rede ...

  3. 修改mysql的binlog的位置

    最近项目上装的mysql服务,分配的磁盘空间太小了,导致binlog两天时间就能打满,这里记录下处理方式 mysql的binlog日志是一个很重要的日志,以事件形式记录了所有的DDL和DML(除了数据 ...

  4. CDN和浏览器缓存

    1,CDN 旨在解决的最重要的问题是什么,我们称之为网络延迟,通过网络获取资源总是比从本地获取慢,无论服务器是在同一个局域网中还是位于世界的另一个角落,都是如此.这里的速度差异是 IT 行业的一个核心 ...

  5. Mac OSX编译安装php5.6

    安装好OSX 10.13以后默认自带的php7.1.7,跟现有环境不兼容,所以准备编译安装php5.6,自带的php7不建议卸载,重新安装一份php5.6 1.安装php的一些依赖,推荐使用brew安 ...

  6. Codeforces Round #344 (Div. 2) 631 B. Print Check (实现)

    B. Print Check time limit per test1 second memory limit per test256 megabytes inputstandard input ou ...

  7. Flight HDU - 3499 (分层最短路)

    Recently, Shua Shua had a big quarrel with his GF. He is so upset that he decides to take a trip to ...

  8. スワコゥのパーフェクトコード教室 ~ Style of suwakow's for OI Codes

    "みんなー! スワコゥのコード教室はじまるよー!" "大家!\(\color{grey}{\text{suwakow}}\)的码风教室开始了哟!" " ...

  9. 51 Nod 1085 01背包问题

    1085 背包问题  基准时间限制:1 秒 空间限制:131072 KB 分值: 0 难度:基础题  收藏  关注 在N件物品取出若干件放在容量为W的背包里,每件物品的体积为W1,W2--Wn(Wi为 ...

  10. pycharm中调用函数方法自动补全p,m,c,v,f分别是什么意思

    p:parameter 参数m:method 方法c:class 类v:variable 变量f:function 函数