C++異步調(diào)用方法詳解
future和promise的作用是在不同線程之間傳遞數(shù)據(jù)。使用指針也可以完成數(shù)據(jù)的傳遞,但是指針非常危險,因為互斥量不能阻止指針的訪問;而且指針的方式傳遞的數(shù)據(jù)是固定的,如果更改數(shù)據(jù)類型,那么還需要更改有關(guān)的接口,比較麻煩;promise支持泛型的操作,更加方便編程處理。
假設(shè)線程1需要線程2的數(shù)據(jù),那么組合使用方式如下:
線程1初始化一個promise對象和一個future對象,promise傳遞給線程2,相當(dāng)于線程2對線程1的一個承諾;future相當(dāng)于一個接受一個承諾,用來獲取未來線程2傳遞的值
線程2獲取到promise后,需要對這個promise傳遞有關(guān)的數(shù)據(jù),之后線程1的future就可以獲取數(shù)據(jù)了。
如果線程1想要獲取數(shù)據(jù),而線程2未給出數(shù)據(jù),則線程1阻塞,直到線程2的數(shù)據(jù)到達(dá)。
future對象是std::async、std::promise、std::packaged_task的底層對象,用來傳遞其他線程中操作的數(shù)據(jù)結(jié)果。
std::promise的作用就是提供一個不同線程之間的數(shù)據(jù)同步機制,它可以存儲一個某種類型的值,并將其傳遞給對應(yīng)的future, 即使這個future不在同一個線程中也可以安全的訪問到這個值。
#include <iostream> #include <functional> #include <future> #include <thread> #include <chrono> #include <cstdlib> void thread_set_promise(std::promise<int>& promiseObj) { std::cout << "In a thread, making data...\n"; std::this_thread::sleep_for(std::chrono::milliseconds(1000)); promiseObj.set_value(35); std::cout << "Finished\n"; } int main() { std::promise<int> promiseObj; std::future<int> futureObj = promiseObj.get_future(); std::thread t(&thread_set_promise, std::ref(promiseObj)); std::cout << futureObj.get() << std::endl; t.join(); system("pause"); return 0; }
async(高級封裝future和thread)
std::future可以從異步任務(wù)中獲取結(jié)果,一般與std::async配合使用,std::async用于創(chuàng)建異步任務(wù),實際上就是創(chuàng)建一個線程執(zhí)行相應(yīng)任務(wù)。
std::async就是異步編程的高級封裝,封裝了std::future的操作,基本上可以代替std::thread 的所有事情。
std::async的操作,其實相當(dāng)于封裝了std::promise、std::packaged_task加上std::thread。
#include <iostream> // std::cout #include <future> // std::async, std::future #include <chrono> // std::chrono::milliseconds bool is_prime (int x) { for (int i=2; i<x; ++i) if (x%i==0) return false; return true; } int main () { // call function asynchronously: std::future<bool> fut = std::async (is_prime,444444443); // do something while waiting for function to set future: std::cout << "checking, please wait"; std::chrono::milliseconds span (100); while (fut.wait_for(span)==std::future_status::timeout) std::cout << '.' << std::flush; bool x = fut.get(); // retrieve return value std::cout << "\n444444443 " << (x?"is":"is not") << " prime.\n"; return 0; }
std::async會首先創(chuàng)建線程執(zhí)行is_prime(444444443), 任務(wù)創(chuàng)建之后,std::async立即返回一個std::future對象。
主線程既可使用std::future::get獲取結(jié)果,如果調(diào)用過程中,任務(wù)尚未完成,則主線程阻塞至任務(wù)完成。
主線程也可使用std::future::wait_for等待結(jié)果返回,wait_for可設(shè)置超時時間,如果在超時時間之內(nèi)任務(wù)完成,則返回std::future_status::ready狀態(tài);如果在超時時間之內(nèi)任務(wù)尚未完成,則返回std::future_status::timeout狀態(tài)。
到此這篇關(guān)于C++異步調(diào)用方法的文章就介紹到這了,更多相關(guān)C++異步調(diào)用內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
C++11中的智能指針shared_ptr、weak_ptr源碼解析
本文是基于gcc-4.9.0的源代碼進行分析,shared_ptr和weak_ptr是C++11才加入標(biāo)準(zhǔn)的,僅對C++智能指針shared_ptr、weak_ptr源碼進行解析,需要讀者有一定的C++基礎(chǔ)并且對智能指針有所了解2021-09-09