c语言线程锁的原理开锁原理图,C++多线程之可重入锁

#include

#include

#include

using namespace std;

recursive_mutex re;

void task1()

{

re.lock();

cout << "处理任务1中..." << endl;

std::this_thread::sleep_for(1s);

re.unlock();

}

void task2()

{

re.lock();

cout << "处理任务2中..." << endl;

std::this_thread::sleep_for(1s);

re.unlock();

}

class ThreadBase

{

public:

virtual void Start()

{

is_exit = false;

th = std::thread(&ThreadBase::Main,this);

}

virtual void Stop()

{

is_exit = true;

Wait();

}

virtual void Wait()

{

if (th.joinable())

{

th.join();

}

}

bool get_exit()

{

return is_exit;

}

virtual void Main() = 0;

ThreadBase(int _i):i(_i) {}

virtual ~ThreadBase() {}

int i;

private:

std::thread th;

bool is_exit;

};

class MyThread:public ThreadBase

{

public:

MyThread(int i):ThreadBase(i) {}

~MyThread() override {}

void Main() override

{

for (;;)

{

//如果不是可重入锁,那么得先开锁然后才能执行task1,否则会造成死锁

//但是如果开锁,也就是在一个线程执行任务时,另一个线程也进来了,如果另一个线程执行了一会就结束了,肯定会

//释放锁,而实际上线程一的任务还没执行完

re.lock();

cout << "线程" << i << "拿到了锁" << endl;

task1();

task2();

re.unlock();

std::this_thread::sleep_for(1ms);

}

}

};

int main(int argc,char* argv[])

{

MyThread th_one(1);

th_one.Start();

th_one.Wait();

getchar();

return 0;

}

原文:https://www.cnblogs.com/SunShine-gzw/p/14530107.html

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值