C++26 不包含 std::execution(P2300),该提案已在 2025 年 Kona 会议被 WG21 正式否决;主因是范围失控与实现脱节,主流标准库尚无符合语义的运行时支持。C++26 的
std::execution(P2300)**不会落地**——它已被 WG21 在 2025 年 2 月的 Kona 会议上正式否决,**不会成为 C++26 的一部分**。
这意味着:你不需要为“C++26 的 Sender/Receiver 模型”做任何迁移准备,它目前不存在于标准时间线中。
核心问题不是技术不成熟,而是“范围失控 + 实现脱节”:
sender/receiver 原本想统一异步操作(如 std::async、协程 awaitables、网络 I/O),但最终提案膨胀到必须重定义执行器(executor)、调度语义、错误传播、取消机制,甚至影响 std::thread 和 std::jthread 的抽象层当前可行路径非常明确:
co_await + 自定义 awaiter 封装任意异步源(如 libuv、asio、WinRT),稳定、可调试、编译期检查强boost::asio(v1.83+ 已深度集成 sender/receiver-like 语义,但不依赖 P2300)、facebook/folly、Microsoft/cppwinrt 都提供生产级异步原语std::jthread、std::latch/std::semaphore、C++23 的 std::stacktrace 和改进的 std::format,用于辅助而非驱动异步流有,但路径已重置:
std::task 简化协程包装)sender 概念,不绑定执行器)std::execution 模块已从 C++26 tracking issue 中移除,归档至 “Deferred” 标签// 当前最接近“标准 sender”风格的合法写法(C++23,无需 P2300) #include真正要警惕的,不是“怎么用 sender”,而是误信某些博客或会议幻灯片里“C++26 已包含 P2300”的过时信息——标准进程是公开、缓慢、高度保守的,所有变更都能在 cplusplus/papers 里查到原始记录。#include template struct task { struct promise_type { T value_; std::exception_ptr ex_; auto get_return_object() { return task{}; } auto initial_suspend() { return std::suspend_always{}; } auto final_suspend() noexcept { return std::suspend_always{}; } void return_value(T v) { value_ = std::move(v); } void unhandled_exception() { ex_ = std::current_exception(); } }; };