C++11 新特性:多线程支持 - std::timed_mutex

2024-04-19 11:44

本文主要是介绍C++11 新特性:多线程支持 - std::timed_mutex,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

C++11 标准库中的std::timed_mutexstd::recursive_timed_mutex是两种提供超时功能的互斥锁。

std::mutexstd::recursive_mutex提供的基本互斥功能相比,这两种类型的锁允许线程尝试获取锁一段时间,并在超时后放弃,增加了更多控制线程等待锁的灵活性。

今天先来看看std::timed_mutex的用法。

std::timed_mutex

std::timed_mutex提供了基本的互斥功能,同时支持超时。它允许线程尝试锁定互斥量一段指定的时间。

如果在指定时间内没有获取到锁,线程可以选择放弃等待,执行其他操作。

std::timed_mutex主要提供了两个成员函数用于带超时的锁操作:

  • try_lock_for():接受一个时间段,如果在这段时间内能够获得锁,则返回true,否则在超时后返回false
  • try_lock_until():接受一个绝对时间点,如果在这个时间点之前能够获得锁,则返回true,否则在超时后返回false

try_lock_for()用法示例

下面是一个使用std::timed_mutex的示例,演示了如何使用try_lock_for()方法:

#include <iostream>
#include <chrono>
#include <thread>
#include <mutex>std::timed_mutex mtx;void fireworks(int id) {// 等待最多1秒尝试获取锁if (mtx.try_lock_for(std::chrono::seconds(1))) {std::this_thread::sleep_for(std::chrono::milliseconds(200)); // 模拟烟花std::cout << "Firework " << id << std::endl;mtx.unlock();} else {// 超时处理std::cout << "Thread " << id << " couldn't get the lock" << std::endl;}
}int main() {std::thread threads[10];for (int i = 0; i < 10; ++i) {threads[i] = std::thread(fireworks, i + 1);}for (auto& t : threads) {t.join();}return 0;
}

一种可能的输出:

Firework 1
Firework 2
Firework 3
Firework 4
Thread 6 couldn't get the lock
Thread 7 couldn't get the lock
Thread 8 couldn't get the lock
Thread 9 couldn't get the lock
Thread 10 couldn't get the lock
Firework 5

在这个示例中,多个线程尝试获取同一个std::timed_mutex

使用try_lock_for(),每个线程在等待1秒钟尝试获取锁后,要么成功获得锁并继续执行,要么因为超时而放弃。

try_lock_until()用法示例

#include <iostream>
#include <mutex>
#include <chrono>
#include <thread>std::timed_mutex tmx;void attempt_to_lock_until(int id, const std::chrono::time_point<std::chrono::system_clock>& timeout_time) {if (tmx.try_lock_until(timeout_time)) {std::cout << "Thread " << id << " acquired the lock" << std::endl;std::this_thread::sleep_for(std::chrono::seconds(1)); // 模拟工作tmx.unlock();} else {std::cout << "Thread " << id << " failed to acquire the lock" << std::endl;}
}int main() {auto timeout_time = std::chrono::system_clock::now() + std::chrono::seconds(3);std::thread t1(attempt_to_lock_until, 1, timeout_time);std::thread t2(attempt_to_lock_until, 2, timeout_time);t1.join();t2.join();return 0;
}

输出:

Thread 2 acquired the lock
Thread 1 acquired the lock

总结

std::timed_mutex可以让线程在等待获取互斥量的过程中考虑超时,这对于需要避免长时间等待的场景特别有用。

这篇关于C++11 新特性:多线程支持 - std::timed_mutex的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/917443

相关文章

深入解析C++ 中std::map内存管理

《深入解析C++中std::map内存管理》文章详解C++std::map内存管理,指出clear()仅删除元素可能不释放底层内存,建议用swap()与空map交换以彻底释放,针对指针类型需手动de... 目录1️、基本清空std::map2️、使用 swap 彻底释放内存3️、map 中存储指针类型的对象

Python多线程实现大文件快速下载的代码实现

《Python多线程实现大文件快速下载的代码实现》在互联网时代,文件下载是日常操作之一,尤其是大文件,然而,网络条件不稳定或带宽有限时,下载速度会变得很慢,本文将介绍如何使用Python实现多线程下载... 目录引言一、多线程下载原理二、python实现多线程下载代码说明:三、实战案例四、注意事项五、总结引

C++ STL-string类底层实现过程

《C++STL-string类底层实现过程》本文实现了一个简易的string类,涵盖动态数组存储、深拷贝机制、迭代器支持、容量调整、字符串修改、运算符重载等功能,模拟标准string核心特性,重点强... 目录实现框架一、默认成员函数1.默认构造函数2.构造函数3.拷贝构造函数(重点)4.赋值运算符重载函数

C++ vector越界问题的完整解决方案

《C++vector越界问题的完整解决方案》在C++开发中,std::vector作为最常用的动态数组容器,其便捷性与性能优势使其成为处理可变长度数据的首选,然而,数组越界访问始终是威胁程序稳定性的... 目录引言一、vector越界的底层原理与危害1.1 越界访问的本质原因1.2 越界访问的实际危害二、基

Python多线程应用中的卡死问题优化方案指南

《Python多线程应用中的卡死问题优化方案指南》在利用Python语言开发某查询软件时,遇到了点击搜索按钮后软件卡死的问题,本文将简单分析一下出现的原因以及对应的优化方案,希望对大家有所帮助... 目录问题描述优化方案1. 网络请求优化2. 多线程架构优化3. 全局异常处理4. 配置管理优化优化效果1.

c++日志库log4cplus快速入门小结

《c++日志库log4cplus快速入门小结》文章浏览阅读1.1w次,点赞9次,收藏44次。本文介绍Log4cplus,一种适用于C++的线程安全日志记录API,提供灵活的日志管理和配置控制。文章涵盖... 目录简介日志等级配置文件使用关于初始化使用示例总结参考资料简介log4j 用于Java,log4c

C++归并排序代码实现示例代码

《C++归并排序代码实现示例代码》归并排序将待排序数组分成两个子数组,分别对这两个子数组进行排序,然后将排序好的子数组合并,得到排序后的数组,:本文主要介绍C++归并排序代码实现的相关资料,需要的... 目录1 算法核心思想2 代码实现3 算法时间复杂度1 算法核心思想归并排序是一种高效的排序方式,需要用

Qt中实现多线程导出数据功能的四种方式小结

《Qt中实现多线程导出数据功能的四种方式小结》在以往的项目开发中,在很多地方用到了多线程,本文将记录下在Qt开发中用到的多线程技术实现方法,以导出指定范围的数字到txt文件为例,展示多线程不同的实现方... 目录前言导出文件的示例工具类QThreadQObject的moveToThread方法实现多线程QC

Go语言使用sync.Mutex实现资源加锁

《Go语言使用sync.Mutex实现资源加锁》数据共享是一把双刃剑,Go语言为我们提供了sync.Mutex,一种最基础也是最常用的加锁方式,用于保证在任意时刻只有一个goroutine能访问共享... 目录一、什么是 Mutex二、为什么需要加锁三、实战案例:并发安全的计数器1. 未加锁示例(存在竞态)

C++11范围for初始化列表auto decltype详解

《C++11范围for初始化列表autodecltype详解》C++11引入auto类型推导、decltype类型推断、统一列表初始化、范围for循环及智能指针,提升代码简洁性、类型安全与资源管理效... 目录C++11新特性1. 自动类型推导auto1.1 基本语法2. decltype3. 列表初始化3