时间:2021-05-20
使用C++11标准的的线程语法,用两个线程轮流打印整数,一个线程打印奇数,一个线程打印偶数。可以练习线程的基本操作、线程锁和条件变量等技术。完整代码如下。代码后面附有主要语句的讲解。
#include <thread>#include <iostream>#include <mutex>#include <condition_variable> std::mutex data_mutex;std::condition_variable data_var;bool label = false; void printodd(){ std::unique_lock<std::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 <<std::endl; label = false; data_var.notify_one(); }} void printeven(){ std::unique_lock<std::mutex> ulock(data_mutex) ; for(int even = 0; even < 100; even += 2 ) { std::cout<< std::this_thread::get_id() << ": " << even <<std::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<<"end!"<<std::endl; return 0;}程序中使用std::unique_lock<std::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线程打印整数内容请搜索以前的文章或继续浏览下面的相关文章希望大家以后多多支持!
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
1,简介C++11中加入了头文件,此头文件主要声明了std::thread线程类。C++11的标准类std::thread对线程进行了封装,定义了C++11标准
前言C++类中有几个特殊的非静态成员函数,当用户未定义这些函数时,编译器将给出默认实现。C++11前有四个特殊函数,C++11引入移动语义特性,增加了两个参数为
在C++11以前,C++的多线程编程均需依赖系统或第三方接口实现,一定程度上影响了代码的移植性。C++11中,引入了boost库中的多线程部分内容,形成C++标
首先打印1-100数字如果用一个单线程实现那么只要一个for循环即可,那么如果要用两个线程打印出来呢?(一个线程打印奇数,一个线程打印偶数)于是大家会想到可以通
问题描述:两个go程轮流打印一个切片。Golang实现:使用两个channel,只用来判断packagemainimport("fmt""sync")//两个g