您好,登錄后才能下訂單哦!
這篇“C++11的std::future對象如何使用”文章的知識點大部分人都不太理解,所以小編給大家總結了以下內容,內容詳細,步驟清晰,具有一定的借鑒價值,希望大家閱讀完這篇文章能有所收獲,下面我們一起來看看這篇“C++11的std::future對象如何使用”文章吧。
在前面幾篇文章中基本都用到thread對象,它是C++11中提供異步創建多線程的工具。
但是我們想要從線程中返回異步任務結果,一般需要依靠全局變量;從安全角度看,有些不妥;為此C++11提供了std::future類模板,future對象提供訪問異步操作結果的機制,很輕松解決從異步任務中返回結果。
在C++標準庫中,有兩種“期望”
使用兩種類型模板實現
唯一期望(unique futures,std::future<>) std::future的實例只能與一個指定事件相關聯。
共享期望(shared futures)(std::shared_future<>) std::shared_future的實例就能關聯多個事件。
這里主要介紹的是唯一期望,std::future類模板定義頭文件<future>
其函數聲明如下:
template< class T > class future; //數據有關的期望 template< class T > class future<T&>; //數據無關的期望 template<> class future<void>;
對于future補充說明如下:
std::async 、std::packaged_task 或 std::promise 能提供一個std::future對象給該異步操作的創建者
異步操作的創建者能用各種方法查詢、等待或從 std::future 提取值。若異步操作仍未提供值,則這些方法可能阻塞。
異步操作準備好發送結果給創建者時,它能通過接口(eg,std::promise::set_value std::future) 修改共享狀態的值。
其成員函數如下:
其函數聲明如下:
void wait() const;
當共享狀態值是不可以用時,調用wait接口可以一直阻塞,直到共享狀態變為"就緒"時,就變為可以用了。
get是獲取共享狀態的結果它有以下三種形式:
//僅為泛型 future 模板的成員 T get(); //(僅為 future<T&> 模板特化的成員) T& get(); //僅為 future<void> 模板特化的成員 void get();
如果我們沒有調用wait接口,而是直接掉用get接口,它等價于先調用wait()而后在調用get接口,得到異步操作的結果。
當調用此方法后 valid() 為 false ,共享狀態被釋放,即future對象釋一次性的事件。
按照自己的理解,將std::future對象的使用以及內部邏輯用時序圖進行表達,如下:
下面就用std::future對象來獲取異步操作的結果,沒有使用到全局變量,邏輯非常清晰
代碼如下:
//通過async來獲取異步操作結果 std::future<int> result = std::async([](){ std::this_thread::sleep_for(std::chrono::milliseconds(500)); return 8; }); std::cout << "the future result : " << result.get() << std::endl; std::cout << "the future status : " << result.valid() << std::endl; try { result.wait(); //或者 result.get() ,會異常 //因此std::future只能用于單線程中調用 ,多線程調用使用std::share_future(); } catch (...) { std::cout << "get error....\n "; }
運行結果:
以上就是關于“C++11的std::future對象如何使用”這篇文章的內容,相信大家都有了一定的了解,希望小編分享的內容對大家有幫助,若想了解更多相關的知識內容,請關注億速云行業資訊頻道。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。