cplusplus
.com
教程
參考
文章
論壇
C++
教程
參考
文章
論壇
參考
C 庫
<cassert> (assert.h)
<cctype> (ctype.h)
<cerrno> (errno.h)
C++11
<cfenv> (fenv.h)
<cfloat> (float.h)
C++11
<cinttypes> (inttypes.h)
<ciso646> (iso646.h)
<climits> (limits.h)
<clocale> (locale.h)
<cmath> (math.h)
<csetjmp> (setjmp.h)
<csignal> (signal.h)
<cstdarg> (stdarg.h)
C++11
<cstdbool> (stdbool.h)
<cstddef> (stddef.h)
C++11
<cstdint> (stdint.h)
<cstdio> (stdio.h)
<cstdlib> (stdlib.h)
<cstring> (string.h)
C++11
<ctgmath> (tgmath.h)
<ctime> (time.h)
C++11
<cuchar> (uchar.h)
<cwchar> (wchar.h)
<cwctype> (wctype.h)
容器
C++11
<array>
<deque>
C++11
<forward_list>
<list>
<map>
<queue>
<set>
<stack>
C++11
<unordered_map>
C++11
<unordered_set>
<vector>
輸入/輸出
<fstream>
<iomanip>
<ios>
<iosfwd>
<iostream>
<istream>
<ostream>
<sstream>
<streambuf>
多執行緒
C++11
<atomic>
C++11
<condition_variable>
C++11
<future>
C++11
<mutex>
C++11
<thread>
其他
<algorithm>
<bitset>
C++11
<chrono>
C++11
<codecvt>
<complex>
<exception>
<functional>
C++11
<initializer_list>
<iterator>
<limits>
<locale>
<memory>
<new>
<numeric>
C++11
<random>
C++11
<ratio>
C++11
<regex>
<stdexcept>
<string>
C++11
<system_error>
C++11
<tuple>
C++11
<type_traits>
C++11
<typeindex>
<typeinfo>
<utility>
<valarray>
<future>
類
C++11
future
C++11
future_error
C++11
packaged_task
C++11
promise
C++11
shared_future
列舉類
C++11
future_errc
C++11
future_status
C++11
launch
函式
C++11
async
C++11
future_category
packaged_task
C++11
packaged_task::~packaged_task
C++11
packaged_task::packaged_task
成員函式
C++11
packaged_task::get_future
C++11
packaged_task::make_ready_at_thread_exit
C++11
packaged_task::operator()
C++11
packaged_task::operator=
C++11
packaged_task::reset
C++11
packaged_task::swap
C++11
packaged_task::valid
非成員過載
C++11
swap (packaged_task)
非成員特化
C++11
uses_allocator<packaged_task>
參考
<future>
packaged_task
make_ready_at_thread_exit
public member function
<future>
std::
packaged_task
::make_ready_at_thread_exit
void make_ready_at_thread_exit (args... args);
呼叫儲存的任務,線上程退出時使其就緒
呼叫
儲存的任務
,將
args
作為引數轉發,就像呼叫其
operator()
成員一樣,但不同於呼叫完成後立即使
共享狀態
就緒,而是使
共享狀態
線上程退出時就緒。
如果一個與同一
共享狀態
關聯的
future
物件正在等待
future::get
的呼叫,它將保持阻塞直到執行緒結束。一旦執行緒結束,對
future::get
的呼叫將解除阻塞並返回或丟擲異常。
請注意,呼叫此函式已設定
共享狀態
中的值,任何在此呼叫和執行緒結束之間嘗試修改此值的呼叫都將丟擲
future_error
,並將
promise_already_satisfied
作為
錯誤條件
。
引數
args...
呼叫的引數。
Args...
是
packaged_task
的模板引數,它們代表
儲存的任務
的引數型別。
返回值
無。
資料競爭
*packaged_task*已被修改。
共享狀態
被修改為
原子操作
(不引起資料競爭),同步線上程結束時發生。
異常安全
基本保證:
如果丟擲異常,*
packaged_task
*處於有效狀態。
此成員函式在以下條件下丟擲異常
exception type
error condition
描述
future_error
future_errc::no_state
該物件沒有*共享狀態*(它是*
預設構造
*的*
packaged_task
*)。
future_error
future_errc::promise_already_satisfied
儲存的任務
已被呼叫
此成員函式還會在引數的任何複製或移動操作丟擲異常時丟擲,並且(取決於庫實現)也可能丟擲以報告其他情況。
另見
packaged_task::operator()
呼叫儲存的任務
(public member function)
packaged_task::get_future
獲取 future
(public member function)
future::get
Get value
(public member function)