C++ 多线程编程

转自:C++标准线程库之共享资源

1 带普通互斥锁的多线程案例

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

class X
{
	int* _p;
	mutex m1;
public:
	X(int* p = nullptr) :_p(p) {}
	~X() { if (_p) delete _p; }

	void read()
	{
		m1.lock();
		if (_p)
			cout << "werggvgvdfvgfsdvytf value:" << *_p << endl;
		else
			cout << "Is NULL !" << endl;
		m1.unlock();
	}
	void reset()
	{
		m1.lock();
		cout << "resetting..." << endl;
		if (_p)
		{
			delete _p;
			_p = nullptr;
		}
		cout << "resetting done!" << endl;
		m1.unlock();
	}
	void set(int x)
	{
		
		m1.lock();
		if (_p)
			*_p = x;
		else
			_p = new int(x);
		m1.unlock();
	}
};
int main()
{
	int* pint = new int(77);
	X* px1 = new X(pint);
	thread t1(&X::read, px1), t2(&X::reset, px1);
	t1.detach();
	t2.detach();
	px1->read();
	system("pause");
	return 0;
}

运行结果:
在这里插入图片描述
或:
在这里插入图片描述

2 lock_gard/unique_lock 自动锁

其中lock_guard是对lock的轻量化封装,构造函数内有lock(),析构函数有unlock(),unique_lock功能更多,但是较慢较大。

void read()
	{
		lock_guard<mutex> lk(m1);//声明一个lock_guard变量lk,模板参数类型为mutex,参数为mutex类型的m1.
		if (_p)
			cout << "werggvgvdfvgfsdvytf value:" << *_p << endl;
		else
			cout << "Is NULL !" << endl;
	}
	void reset()
	{
		lock_guard<mutex> lk(m1);
		cout << "resetting..." << endl;
		if (_p)
		{
			delete _p;
			_p = nullptr;
		}
		cout << "resetting done!" << endl;
	}
	void set(int x)
	{
		lock_guard<mutex> lk(m1);
		if (_p)
			*_p = x;
		else
			_p = new int(x);
	}

结果与上一致。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值