【C++】多线程(四)
2023-12-24 18:26:06
这是多线程的最后一篇文章。
std::promise
promise 的作用很简单,在一个线程t1中保存一个类型typename T的值,可供相绑定的std::future对象在另一线程t2中获取。事实上,它与future基本是成对出现的。来看下面的例子:
//声明一个std::promise对象pr1,其保存的值类型为int
promise<int> pr1;
//声明一个std::future对象fu1,并通过std::promise的get_future()函数与pr1绑定
future<int> fu1 = pr1.get_future();
promise和future之间是通过get_future()绑定的,对于一个promise而言,只能调用一次get_future()。
之后创建两个线程,线程1为promise赋值,线程2使用promise的值。
void Thread_Fun1(promise<int> &p)
{
int iVal = 233;
cout << "传入数据(int):" << iVal << endl;
//传入数据iVal
p.set_value(iVal);
}
void Thread_Fun2(future<int> &f)
{
//阻塞函数,直到收到相关联的std::promise对象传入的数据
auto iVal = f.get(); //iVal = 233
cout << "收到数据(int):" << iVal << endl;
}
//创建一个线程t1,将函数Thread_Fun1及对象pr1放在线程里面执行
thread t1(Thread_Fun1, ref(pr1));
//创建一个线程t2,将函数Thread_Fun2及对象fu1放在线程里面执行
thread t2(Thread_Fun2, ref(fu1));
//阻塞至线程结束
t1.join();
t2.join();
如果你对操作系统有一定的了解,你会发现,这有点像“生产者-消费者”问题,promise相当于生产者,future相当于消费者。
当然不能说promise的唯一意义就是让thread可以通过future传递一个返回值回来,反正有万能的引用。鉴于我公司的项目里对这个用得比较少,我也无法解释更多的含义了。
线程对自身的控制
thread所有针对自身的控制都在命名空间this_thread里,我这里介绍两个:
sleep_for
每次我学这种函数,我都有种无语的感觉。只是因为C语言的sleep()与平台有关,C++就要搞一个另外的sleep_for()出来,然后参数还是特别离谱的duraction,然后优点还是能保证底层以及多平台的兼容性… …唉。
说回正题,sleep_for()可以让线程暂停一段时间。比如刚才的函数就可以这么用:
void Thread_Fun1(promise<int> &p)
{
this_thread::sleep_for(chrono::seconds(10));
int iVal = 233;
cout << "传入数据(int):" << iVal << endl;
//传入数据iVal
p.set_value(iVal);
}
yield
yield()的作用是当前线程“放弃”执行,让操作系统调度另一线程继续执行。当然不是永久放弃,而是暂时交出时间片供操作系统调度,过一会会还回来的。
比如你在等待某个操作完成,循环while会使得操作系统没办法分资源给等待的线程出现死锁。这时就可以用yield()暂时交出控制权。
while(!isDone()); // 错误的写法,有可能死锁
while(!isDone()) yield(); // 正确的写法,暂时交出控制权
文章来源:https://blog.csdn.net/qq_37387199/article/details/135182622
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。 如若内容造成侵权/违法违规/事实不符,请联系我的编程经验分享网邮箱:veading@qq.com进行投诉反馈,一经查实,立即删除!
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。 如若内容造成侵权/违法违规/事实不符,请联系我的编程经验分享网邮箱:veading@qq.com进行投诉反馈,一经查实,立即删除!