0

0

c++26的Executors提案将如何改变并发编程? (统一异步模型)

裘德小鎮的故事

裘德小鎮的故事

发布时间:2026-01-14 16:51:03

|

141人浏览过

|

来源于php中文网

原创

C++26未引入Executor标准类型,而是以sender/receiver契约、schedule/then等组合原语替代;并发改进聚焦std::jthread自动停止与stop_token泛化。

c++26的executors提案将如何改变并发编程? (统一异步模型)

UP简历
UP简历

基于AI技术的免费在线简历制作工具

下载
C++26 的 Executors 提案(P0443R14 及后续修订)**不会落地为标准库的一部分**——它已被拆解、重构,并以更小粒度的组件形式分散进入 C++26,核心目标不是“统一异步模型”,而是**提供可组合、可定制的执行抽象基元,供更高层库(如 std::asyncstd::jthread、协程库)底层复用**。

Executors 没有直接暴露 executor 类型给用户

你不会在 C++26 标准头文件里看到 std::executorstd::thread_pool_executor。提案最终放弃“一刀切”的 executor 接口设计,转而聚焦于:

  • std::execution::senderstd::execution::receiver:定义异步操作的生产者/消费者契约(用于 std::async 和协程 awaiter 互操作)
  • std::execution::schedule():最简调度原语,返回一个 sender,表示“在某个隐式执行上下文中就绪”
  • std::execution::then()std::execution::upon_error() 等适配器:用于组合 sender 链,但不强制绑定到具体线程或队列
这意味着:你写异步逻辑时仍用 co_awaitstd::async,只是它们底层可能共享同一套 sender/receiver 调度语义,而非各自实现一套线程分发逻辑。

C++26 中真正可用的并发新特性是 std::jthread 增强与 std::stop_token 泛化

相比遥不可及的 executor 模型,C++26 更实在的并发改进集中在协作式取消和线程生命周期管理:

  • std::jthread 现在支持构造时传入 std::stop_token,且其析构自动调用 request_stop() —— 不再需要手动 join()detach()
  • std::stop_sourcestd::stop_token 可跨 std::threadstd::jthread、甚至协程作用域传递,取消信号真正可穿透异步
  • std::this_thread::get_stop_token() 成为标准函数,协程中可直接获取当前线程的停止句柄
#include 
#include 
#include 

void worker(std::stop_token stoken) {
  while (!stoken.stop_requested()) {
    // 工作中...
    std::this_thread::sleep_for(10ms);
  }
}

int main() {
  std::jthread t{worker}; // 自动绑定 stop_source,析构时 request_stop()
  // 不需要显式 t.request_stop() 或 t.join()
}

第三方库(如 libunifex、cppcoro)已比标准更早实践了 executor 思想

如果你真想用类 executor 的调度模型,现在就得依赖外部库:

  • libunifex 提供 inline_schedulerthread_poolsingle_thread_context 等具体调度器,API 接近 P0443 原始设计
  • 它的 submit()schedule()let_value() 等操作符可直接组合,且与 C++23 协程兼容
  • 但注意:这些类型与标准 std::execution::sender 并不 ABI 兼容,C++26 的 sender 是简化版,两者不能混用
所以别指望“C++26 一出,所有异步代码自动升级”——迁移成本仍在,且标准只铺路,不造车。 真正容易被忽略的一点:C++26 的执行语义变更几乎全部围绕「取消传播」和「sender 组合性」展开,而不是性能或线程模型抽象。如果你的代码还没用 std::stop_token,那 executor 提案对你当前项目基本没影响。

相关专题

更多
硬盘接口类型介绍
硬盘接口类型介绍

硬盘接口类型有IDE、SATA、SCSI、Fibre Channel、USB、eSATA、mSATA、PCIe等等。详细介绍:1、IDE接口是一种并行接口,主要用于连接硬盘和光驱等设备,它主要有两种类型:ATA和ATAPI,IDE接口已经逐渐被SATA接口;2、SATA接口是一种串行接口,相较于IDE接口,它具有更高的传输速度、更低的功耗和更小的体积;3、SCSI接口等等。

1017

2023.10.19

PHP接口编写教程
PHP接口编写教程

本专题整合了PHP接口编写教程,阅读专题下面的文章了解更多详细内容。

62

2025.10.17

php8.4实现接口限流的教程
php8.4实现接口限流的教程

PHP8.4本身不内置限流功能,需借助Redis(令牌桶)或Swoole(漏桶)实现;文件锁因I/O瓶颈、无跨机共享、秒级精度等缺陷不适用高并发场景。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

393

2025.12.29

堆和栈的区别
堆和栈的区别

堆和栈的区别:1、内存分配方式不同;2、大小不同;3、数据访问方式不同;4、数据的生命周期。本专题为大家提供堆和栈的区别的相关的文章、下载、课程内容,供大家免费下载体验。

387

2023.07.18

堆和栈区别
堆和栈区别

堆(Heap)和栈(Stack)是计算机中两种常见的内存分配机制。它们在内存管理的方式、分配方式以及使用场景上有很大的区别。本文将详细介绍堆和栈的特点、区别以及各自的使用场景。php中文网给大家带来了相关的教程以及文章欢迎大家前来学习阅读。

571

2023.08.10

线程和进程的区别
线程和进程的区别

线程和进程的区别:线程是进程的一部分,用于实现并发和并行操作,而线程共享进程的资源,通信更方便快捷,切换开销较小。本专题为大家提供线程和进程区别相关的各种文章、以及下载和课程。

480

2023.08.10

Java 并发编程高级实践
Java 并发编程高级实践

本专题深入讲解 Java 在高并发开发中的核心技术,涵盖线程模型、Thread 与 Runnable、Lock 与 synchronized、原子类、并发容器、线程池(Executor 框架)、阻塞队列、并发工具类(CountDownLatch、Semaphore)、以及高并发系统设计中的关键策略。通过实战案例帮助学习者全面掌握构建高性能并发应用的工程能力。

60

2025.12.01

Java 桌面应用开发(JavaFX 实战)
Java 桌面应用开发(JavaFX 实战)

本专题系统讲解 Java 在桌面应用开发领域的实战应用,重点围绕 JavaFX 框架,涵盖界面布局、控件使用、事件处理、FXML、样式美化(CSS)、多线程与UI响应优化,以及桌面应用的打包与发布。通过完整示例项目,帮助学习者掌握 使用 Java 构建现代化、跨平台桌面应用程序的核心能力。

0

2026.01.14

php与html混编教程大全
php与html混编教程大全

本专题整合了php和html混编相关教程,阅读专题下面的文章了解更多详细内容。

12

2026.01.13

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
国外Web开发全栈课程全集
国外Web开发全栈课程全集

共12课时 | 1.0万人学习

进程与SOCKET
进程与SOCKET

共6课时 | 0.3万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号