3.C++多线程--数据共享问题

文章介绍了在C++中如何使用互斥量(mutex)来保护共享数据,防止数据竞争。通过std::lock_guard自动管理锁的获取和释放,确保了代码的简洁和安全。同时提到了可能导致死锁的情况,即同时锁住多个锁,并展示了如何使用std::adopt_lock参数来避免这种情况。
摘要由CSDN通过智能技术生成

1.有读有写


保护共享数据:互斥量(mutex)

std::mutex my_mutex

my_mutex.lock();    my_mutex.unlock();

或者使用std::lock_guard<std::mutex> my_lock(my_mutex);

使用lock_guard 在构造函数会调用mutex::lock(),析构函数调用 mutex::unlock();

为了使用lock_guard ,可以配合大括号使用

#include<iostream>
#include<thread>
#include<vector>
#include<list>
#include<mutex>
using namespace std;
class son_thread {
public:
	int m_a;
public:
	son_thread(int a):m_a(a) {

	}
	void product() {
		for (int i = 0; i < 100000; i++) {
			
			{	my_mutex.lock();
				my_list.push_back(i);
				cout << "插入元素:" << i << endl;
				my_mutex.unlock();
			}
		}
		return;
	}
	void consume() {
		my_mutex.lock();
		if (my_list.empty()) {
			cout << "my_list为空" << endl;
		}
		else {
			//std::lock_guard<std::mutex> my_guard(my_mutex);
			int temp = my_list.front();
			my_list.pop_front();
			cout << "my_list:front()的头部元素" << temp << endl;
		}
		my_mutex.unlock();
		return;
	}
	void continue_print() {
		while (1) {
			consume();
		}
	}
private:
	list<int>my_list;
	std::mutex my_mutex;
	//lock_guard<mutex> my_guard;
};
int main() {
	son_thread s1(1);
	thread obj1(&son_thread::product, &s1);
	thread obj2(&son_thread::continue_print, &s1);
	obj1.join();
	obj2.join();
	return 0;
}

2.死锁

同时锁住两个锁。

lock(my_mutex1,my_mutex2);

std::lock_guard的std::adopt_lock参数

std::lock_guardstd::mutex my_guard(my_mutex,std::adopt_lock);
加入adopt_lock后,在调用lock_guard的构造函数时,不再进行lock();
adopt_guard为结构体对象,起一个标记作用,表示这个互斥量已经lock(),不需要在lock()。

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

奋进在AI路上的小李

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值