C++ åèæå
- C++11
- C++14
- C++17
- C++20
- C++ ç¼è¯å¨æ¯ææ åµè¡¨
- ç¬ç«ä¸å®¿ä¸»å®ç°
- C++ è¯è¨
- C++ å ³é®è¯
- é¢å¤çå¨
- C++ æ ååºå¤´æä»¶
- å ·åè¦æ±
- åè½ç¹æ§æµè¯ (C++20)
- å·¥å ·åº
- ç±»åæ¯æï¼åºæ¬ç±»åãRTTIãç±»åç¹æ§ï¼
- æ¦å¿µåº (C++20)
- é误å¤ç
- 卿å å管ç
- æ¥æåæ¶é´å·¥å ·
- å符串åº
- 容å¨åº
- è¿ä»£å¨åº
- èå´åº (C++20)
- ç®æ³åº
- æ°å¼åº
- è¾å ¥/è¾åºåº
- æä»¶ç³»ç»åº
- æ¬å°ååº
- æ£å表达å¼åº
- ååæä½åº
- çº¿ç¨æ¯æåº
- std::thread
- std::stop_token
- std::stop_source
- std::stop_callback
- std::this_thread::get_id
- std::shared_timed_mutex
- std::shared_lock
- std::lock_guard
- std::hardware_destructive_interference_size, std::hardware_constructive_interference_size
- std::counting_semaphore, std::binary_semaphore
- std::jthread
- cpp/thread/barrier
- std::future
- std::this_thread::yield
- std::this_thread::sleep_for
- std::this_thread::sleep_until
- std::mutex
- std::recursive_mutex
- std::shared_mutex
- std::timed_mutex
- std::recursive_timed_mutex
- std::scoped_lock
- std::unique_lock
- std::defer_lock_t, std::try_to_lock_t, std::adopt_lock_t
- std::lock
- std::try_lock
- std::defer_lock, std::try_to_lock, std::adopt_lock
- std::once_flag
- std::call_once
- std::condition_variable
- std::condition_variable_any
- std::notify_all_at_thread_exit
- std::cv_status
- std::latch
- std::promise
- std::shared_future
- std::packaged_task
- std::uses_allocator<std::packaged_task>
- std::swap(std::packaged_task)
- std::async
- std::launch
- std::future_status
- std::future_error
- std::future_category
- std::future_errc
- 注é
- å®éªæ§ C++ ç¹æ§
- æç¨çèµæº
- ç´¢å¼
- std 符å·ç´¢å¼
- åç¨æ¯æ (C++20)
- C++ å ³é®è¯
ä½ç½®ï¼é¦é¡µ > C++ åèæå >çº¿ç¨æ¯æåº > std::packaged_task
std::packaged_task
| å®ä¹äºå¤´æä»¶ <future>
|
||
| template< class > class packaged_task; // ä¸å®ä¹ |
(1) | (C++11 èµ·) |
| template< class R, class ...Args > class packaged_task<R(Args...)>; |
(2) | (C++11 èµ·) |
ç±»æ¨¡æ¿ std::packaged_task å
è£
ä»»ä½å¯è°ç¨ (Callable) ç®æ ï¼å½æ°ã lambda 表达å¼ã bind è¡¨è¾¾å¼æå
¶ä»å½æ°å¯¹è±¡ï¼ï¼ä½¿å¾è½å¼æ¥è°ç¨å®ãå
¶è¿å弿ææå¼å¸¸è¢«åå¨äºè½éè¿ std::future 对象访é®çå
±äº«ç¶æä¸ã
æ£å¦ std::function ï¼ std::packaged_task æ¯å¤æãå
·åé
å¨ç容å¨ï¼å¯å¨å 䏿以æä¾çåé
å¨åé
åå¨çå¯è°ç¨å¯¹è±¡ã
æå彿°
| æé ä»»å¡å¯¹è±¡ (å ¬å¼æå彿°) | |
| ææä»»å¡å¯¹è±¡ (å ¬å¼æå彿°) | |
| ç§»å¨ä»»å¡å¯¹è±¡ (å ¬å¼æå彿°) | |
| æ£æ¥ä»»å¡å¯¹è±¡æ¯å¦æ¥æåæ³å½æ° (å ¬å¼æå彿°) | |
| 交æ¢äºä¸ªä»»å¡å¯¹è±¡ (å ¬å¼æå彿°) | |
è·åç»æ | |
| è¿å䏿¿è¯ºçç»æå
³èç std::future (å ¬å¼æå彿°) | |
æ§è¡ | |
| æ§è¡å½æ° (å ¬å¼æå彿°) | |
| æ§è¡å½æ°ï¼å¹¶ç¡®ä¿ç»æä»
å¨ä¸æ¦å½å线ç¨éåºæ¶å°±ç»ª (å ¬å¼æå彿°) | |
| éç½®ç¶æï¼æå¼ä»»ä½å
åæ§è¡çåå¨ç»æ (å ¬å¼æå彿°) | |
éæå彿°
| ç¹å std::swap ç®æ³ (彿°æ¨¡æ¿) |
帮å©ç±»
| (C++11)(C++17 å) |
ç¹å std::uses_allocator ç±»åç¹å¾ (类模æ¿ç¹å) |
示ä¾
è¿è¡æ¤ä»£ç
#include <iostream> #include <cmath> #include <thread> #include <future> #include <functional>  // é¿å 对 std::pow éè½½éæ¶æ§ä¹çç¬æå½æ° int f(int x, int y) { return std::pow(x,y); }  void task_lambda() { std::packaged_task<int(int,int)> task([](int a, int b) { return std::pow(a, b); }); std::future<int> result = task.get_future();  task(2, 9);  std::cout << "task_lambda:\t" << result.get() << '\n'; }  void task_bind() { std::packaged_task<int()> task(std::bind(f, 2, 11)); std::future<int> result = task.get_future();  task();  std::cout << "task_bind:\t" << result.get() << '\n'; }  void task_thread() { std::packaged_task<int(int,int)> task(f); std::future<int> result = task.get_future();  std::thread task_td(std::move(task), 2, 10); task_td.join();  std::cout << "task_thread:\t" << result.get() << '\n'; }  int main() { task_lambda(); task_bind(); task_thread(); }
è¾åºï¼
task_lambda: 512 task_bind: 2048 task_thread: 1024
åé
| (C++11) |
çå¾
è¢«å¼æ¥è®¾ç½®çå¼ (类模æ¿) |