多线程编程C+++++++++++第9课(超时锁)

这篇文章描述了一个多线程程序中如何使用timed_mutex实现资源的超时锁定。当线程尝试获取资源但等待1000毫秒后仍未成功,线程会释放锁并继续执行,防止长时间阻塞。程序创建了多个线程并发运行,每个线程尝试获取并释放同一个资源,确保临界区的高效访问。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

嗯,我是一个线程,我看不到其他线程,我眼里只有能访问的区域。咦,哪个区域怎么不给我访问,怎么上锁了,我想自己上锁的。我等待把,我等了1000ms还是没等待成功,我该走还是改怎么办呢?他这个锁是超时的,我自己写了一部分代码,检测他是否超时,不然我一直等下去多甜狗。

timed_mutex tmux; //超时锁
if (!tmux.try_lock_for(chrono::milliseconds(1000ms)))
		{
			//尝试锁住(尝试获取资源,等1000ms
			//等了1000ms之后发现,还是没能lock这个临界区,也就是无法获取资源,这个线程就开始抱怨了
			cout<<i<<"[time_out]"<<endl;
			continue;
		}
		//成功获取资源
		cout<<i<<"[in]"<<endl;
		//完成共享区任务后,解锁
		tmux.unlock();
		this_thread::sleep_for(1ms)
		};

整体代码:

/*
笔记:n个线程竞争一个资源,使用临界区上锁方式规定只允许每次一个线程访问该临界区获取资源。临界区需要做得比较小,否则导致资源浪费
		久久不得响应
*/

#include <thread>
#include <iostream>
#include <mutex>
using namespace std;

timed_mutex tmux; //超时锁
static mutex mux;
void test_main(int i) {
	
	while (1) {
	
		if (!tmux.try_lock_for(chrono::milliseconds(1000ms)))
		{
			//尝试锁住(尝试获取资源,等1000ms
			//等了1000ms之后发现,还是没能lock这个临界区,也就是无法获取资源,这个线程就开始抱怨了
			cout<<i<<"[time_out]"<<endl;
			continue;
		}
		//成功获取资源
		cout<<i<<"[in]"<<endl;
		//完成共享区任务后,解锁
		tmux.unlock();
		this_thread::sleep_for(1ms);
	}

}
int main() {

	for (int i = 0; i < 3; i++)
	{//并发8个线程
		std::thread tid(test_main,i+1);
		tid.detach();
	}
	getchar();
	return 0;
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值