C++多線程獲取返回值方法詳解
在許多時(shí)候,我們會(huì)有這樣的需求——即我們想要得到線程返回的值。但是在C++11 多線程中我們注意到,std::thread對(duì)象會(huì)忽略頂層函數(shù)的返回值。
那問題來了,我們要怎么獲得線程的返回值呢?
我們通過一個(gè)例子來說明如何實(shí)現(xiàn)這個(gè)需求。用多個(gè)線程計(jì)算(a+b)/ (x+y) 的值
有兩種方法,分別是
1. 傳統(tǒng)的方法:在線程間共享指針
#include<iostream>
#include<thread>
#include<mutex>
#include<atomic>
using namespace std;
void func2(int x, int y,int* ans) {
*ans= x + y;
}
int main()
{
//計(jì)算(a+b)/(x+y)
//用三個(gè)線程,一個(gè)線程計(jì)算a+b,另一個(gè)線程計(jì)算x+y
int a, b, x, y;
a = 10, b = 8, x = 2, y = 4;
int* sum1 = new int(0);
int* sum2 = new int(0);
thread t1(func2, a, b, sum1);
t1.join();
thread t2(func2, x, y, sum2);
t2.join();
cout << (*sum1) / (*sum2) << endl;
delete sum1;
delete sum2;
system("pause");
return 0;
}
2. C++11的方法:使用std::future和std::promise
std::future和std::promise是封裝好的兩個(gè)類模板,這兩個(gè)類需要配合使用,他們的頭文件是#include<future>
std::future,它表示存儲(chǔ)著一個(gè)未來會(huì)被初始化的變量。這個(gè)變量可以通過std::future提供的成員函數(shù)std::future::get()來得到。如果在這個(gè)變量被賦值之前就有別的線程試圖通過std::future::get()獲取這個(gè)變量,那么這個(gè)線程將會(huì)被阻塞到這個(gè)變量可以獲取為止。
std::promise同樣也是一個(gè)類模板,這個(gè)對(duì)象承諾在未來一定會(huì)初始化一個(gè)變量(這個(gè)變量也就是std::future中的變量)。
每一個(gè)std::promise對(duì)象都有一個(gè)與之關(guān)聯(lián)的std::future對(duì)象。當(dāng)std::promise設(shè)置值的時(shí)候,這個(gè)值就會(huì)賦給std::future中的對(duì)象了。
#include<iostream>
#include<thread>
#include<mutex>
#include<atomic>
#include<future> //std::future std::promise
#include<utility> //std::ref模板傳參的時(shí)候使用
void func2(int x, int y,std::promise<int> &promiseObj) {
promiseObj.set_value(x+y);
}
int main()
{
//計(jì)算(a+b)/(x+y)
//用三個(gè)線程,一個(gè)線程計(jì)算a+b,另一個(gè)線程計(jì)算x+y
int a, b, x, y;
a = 10, b = 8, x = 2, y = 4;
int sum1, sum2;
//聲明一個(gè)類
std::promise<int> promiseObj;
//將future和promise關(guān)聯(lián)
std::future<int> futureObj = promiseObj.get_future();
//模板傳參的時(shí)候使用ref,否則傳參失敗
std::thread t1(func2, a, b, ref(promiseObj));
t1.join();
//獲取值
sum1 = futureObj.get();
std::cout << "sum1=" << sum1 << std::endl;
//不能直接復(fù)用上面的future和promise
std::promise<int> promiseObj2;
std::future<int> futureObj2 = promiseObj2.get_future();
std::thread t2(func2, x, y, ref(promiseObj2));
t2.join();
sum2 = futureObj2.get();
std::cout << "sum2=" << sum2 << std::endl;
std::cout << "sum1/sum2=" << sum1 / sum2 << std::endl;
std::system("pause");
return 0;
}

以上就是本文的全部內(nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
QT實(shí)現(xiàn)QMessageBox中文按鈕示例詳解
這篇文章主要為大家詳細(xì)介紹了QT實(shí)現(xiàn)QMessageBox中文按鈕的相關(guān)知識(shí),文中的示例代碼講解詳細(xì),感興趣的小伙伴可以跟隨小編一起學(xué)習(xí)一下2024-11-11
C++友元函數(shù)與拷貝構(gòu)造函數(shù)詳解
這篇文章主要介紹了C++友元函數(shù)與拷貝構(gòu)造函數(shù),需要的朋友可以參考下2014-07-07
Qt出現(xiàn)假死凍結(jié)現(xiàn)象的原因及解決方法
應(yīng)用程序出現(xiàn)假死或凍結(jié)現(xiàn)象通常是由于一些常見問題所導(dǎo)致的,本文主要介紹了Qt出現(xiàn)假死凍結(jié)現(xiàn)象的原因及解決方法,具有一定的參考價(jià)值,感興趣的可以了解一下2023-10-10
C語言使用函數(shù)實(shí)現(xiàn)字符串部分復(fù)制問題
這篇文章主要介紹了C語言使用函數(shù)實(shí)現(xiàn)字符串部分復(fù)制問題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2022-11-11
C++小知識(shí):C/C++中不要按值傳遞數(shù)組
今天小編就為大家分享一篇關(guān)于C++小知識(shí):C/C++中不要按值傳遞數(shù)組,小編覺得內(nèi)容挺不錯(cuò)的,現(xiàn)在分享給大家,具有很好的參考價(jià)值,需要的朋友一起跟隨小編來看看吧2019-01-01

