c语言父子线程交替打印,C++11用两个线程轮流打印整数的实现方法

使用C++11标准的的线程语法,用两个线程轮流打印整数,一个线程打印奇数,一个线程打印偶数。可以练习线程的基本操作、线程锁和条件变量等技术。完整代码如下。代码后面附有主要语句的讲解。

#include

#include

#include

#include

std::mutex data_mutex;

std::condition_variable data_var;

bool label = false;

void printodd()

{

std::unique_lock<:mutex> ulock(data_mutex) ;

for(int odd = 1; odd <= 100; odd += 2 )

{

data_var.wait(ulock,[]{return label;});

std::cout<< std::this_thread::get_id() << ": " << odd <<:endl>

label = false;

data_var.notify_one();

}

}

void printeven()

{

std::unique_lock<:mutex> ulock(data_mutex) ;

for(int even = 0; even < 100; even += 2 )

{

std::cout<< std::this_thread::get_id() << ": " << even <<:endl>

data_var.notify_one();

label = true;

data_var.wait(ulock,[]{return !label;});

}

}

int main()

{

std::thread t1(printeven);

std::thread t2(printodd);

t1.join();

t2.join();

std::cout<

return 0;

}

程序中使用std::unique_lock<:mutex> ulock(data_mutex)来管理互斥量,

这是一个RAII的资源管理方式,在ulock析构的时候,会自动释放data_mutex。

std::condition_variable提供了两种 wait() 函数。当前线程调用 wait() 后将被阻塞,此时当前线程应该获得了锁(也就是互斥量data_mutex),直到另外某个线程调用 notify_* 唤醒了当前线程。

在线程被阻塞时,该函数会自动调用 data_mutex.unlock() 释放锁,使得其他被阻塞在锁竞争上的线程得以继续执行。另外,一旦当前线程获得通知(notified,通常是另外某个线程调用 notify_* 唤醒了当前线程),wait()函数也是自动调用data_mutex.lock(),使得data_mutex的状态和 wait 函数被调用时相同。

在第二种情况下(即设置了前提条件),只有当前提条件为false时调用 wait() 才会阻塞当前线程,并且在收到其他线程的通知后只有当前提条件为true 时才会被解除阻塞。

总结

到此这篇关于C++11用两个线程轮流打印整数的实现方法的文章就介绍到这了,更多相关C++11线程打印整数内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值