#include <iostream>
#include <future>
#include <thread>
#include <chrono>
void print(char c) {
for (int i = 0;i<10;i++) {
std::cout <<c<<std::flush;
std::this_thread::sleep_for(std::chrono::milliseconds(100));
}
}
void test1() {
print('+');
}
void test2() {
print('-');
}
int main() {
std::future<void> result = std::async(test1); //參數可以是任意的可調用對象
test2();
try{
result.get();
} catch (const std::exception &e) {
std::cout << e.what();
}
return 0;
}
在這個例子中future<>.get() future<>.wait() 表示一定讓線程啓動執行,並且等待其執行結束
發射策略:
- std::launch::async 一定讓線程現在開始執行,如果失敗(比如單線程電腦)就拋出std::system_error
- std::launch::deferred 強制延緩執行,但你在調用get() 或wait()的時候執行
異常處理:
在std::async中拋出異常的話,future object會保持這一狀態直到get被調用,這個異常會傳播到調用get的作用域中。std::async的返回結果一定要用future來接收,一個是爲了獲取結果,一個是爲了確保在線程沒有被啓動時 調用get() wait()來調用啓動
等待和輪詢 :
future<>.wait_for future<>.wait_until 他們兩個並不強制啓動線程(如果線程沒有啓動的話)。返回結果有三種
- std::future_status::deferred
- std::future_status::timeout
- std::future_status::ready