c++11多线程学习笔记之二 mutex使用

本文通过一个C++多线程示例程序,演示了std::mutex中try_lock()与lock()的区别。try_lock()用于尝试获取锁而不阻塞,若锁已被占用,则返回失败;而lock()则会等待锁可用。示例程序展示了当多个线程尝试增加全局计数器时,这两种锁机制的行为差异。

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

// 1111111.cpp : 定义控制台应用程序的入口点。
//

#include "stdafx.h"
#include <iostream>
#include <thread>
#include <mutex>         

int gcounter = 0;
std::mutex gmtx;    
std::mutex gmtxOutput;

void Increases() {
	for (int i = 0; i<10000; ++i) {
		if (gmtx.try_lock()) {   // only increase if currently not locked:
			++gcounter;
			gmtx.unlock();
		}
		else{
			gmtxOutput.lock();
			std::cout << "try lock failed" << std::endl;
			gmtxOutput.unlock();
		}
	}
}

int _tmain(int argc, _TCHAR* argv[]) {
	std::thread threads[10];
	for (int i = 0; i<10; ++i)
		threads[i] = std::thread(Increases);

	for (auto& th : threads) 
		th.join();
	std::cout << "counter is " << gcounter << std::endl;

	return 0;
}

输出:

try lock failed
try lock failed
try lock failed
try lock failed
try lock failed
try lock failed
try lock failed
try lock failed
try lock failed
try lock failed
try lock failed
try lock failed
try lock failed
try lock failed
try lock failed
try lock failed
try lock failed
counter is 99983
请按任意键继续. . .

 这个例子说明了 try_lock() 与 lock()的区别

try_lock()会对能否上锁进行测试 并返回布尔值

而lock()则直接进行锁定 不能锁定则阻塞直到锁定

转载于:https://www.cnblogs.com/itdef/p/4559146.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值