0

0

c# IAsyncEnumerable 的 WithCancellation 扩展方法

星降

星降

发布时间:2026-01-23 11:15:10

|

967人浏览过

|

来源于php中文网

原创

WithCancellation 是 IAsyncEnumerable 的扩展方法,仅挂载 CancellationToken 而不主动触发取消,是否生效取决于底层实现是否响应该 token。

c# iasyncenumerable 的 withcancellation 扩展方法

WithCancellation 是什么,它真能取消 IAsyncEnumerable 的迭代吗?

WithCancellationIAsyncEnumerable 的一个扩展方法,定义在 System.Linq.Async(.NET 5+ 内置,无需额外包),但它**不主动触发取消**,只是把 CancellationToken “挂载”到后续的异步枚举操作上。真正是否响应取消,取决于底层实现——比如 yield return 中是否检查 token,或底层数据源(如 EF Core 查询、HttpClient 流式响应)是否支持取消。

什么时候必须用 WithCancellation?常见误用场景

你不需要在每次遍历前都加 WithCancellation。只有当以下情况之一成立时才需要:

  • 你调用的是第三方 IAsyncEnumerable 方法,且它内部未绑定 token(例如某些自定义 yield 实现漏了 await Task.Delay(..., token)
  • 你在组合多个异步 LINQ 操作(如 WhereSelectTake)后,想确保整个链路可被统一取消
  • 你显式调用 GetAsyncEnumerator() 并手动控制枚举器生命周期(此时必须传 token 给构造器,WithCancellation 是更简洁的替代)

常见误用:在 await foreach 前无脑加 .WithCancellation(token),但底层根本没做 token 检查——结果是取消信号被静默忽略,超时后仍卡住。

如何验证 WithCancellation 是否生效?关键检查点

不能只看代码有没有写 WithCancellation,要确认三点:

沙之丘企业网站程序3.5
沙之丘企业网站程序3.5

沙之丘企业网站程序是一个以asp.net(C#) 4.0 +access进行开发的企业网站源码。主要功能:1、产品、设备、新闻系统2、留言信息直接发邮件到相关部门3、所有链接都以一级目录显示更好的权重4、其他信息扩展,可以增加如:人事招聘,公司介绍,地图,联系我们等5、带有商品和设备的搜索功能6、模板动态化方便扩展模板7、简体繁体选择显示运行环境:windows 2003或者更高windows服务

下载
  • 底层 yield returnawait 调用是否传入了该 token(例如 await stream.ReadAsync(buffer, token),不是 ReadAsync(buffer)
  • 如果用了 EF Core,确保查询是异步的(AsAsyncEnumerable()),且数据库驱动支持取消(SQL Server 支持,SQLite 部分版本不支持)
  • 避免在 yield return 块中做同步阻塞操作(如 Thread.Sleep),这会绕过 token 检查

简单验证示例:

await foreach (var item in GetItemsAsync().WithCancellation(cancellationToken))
{
    // 如果 GetItemsAsync 内部用了 await Task.Delay(1000, cancellationToken)
    // 则 cancellation 可中断等待;否则不会
}

替代方案:不用 WithCancellation 也能安全取消

多数现代框架已默认集成 token 传递,直接传参比后期挂载更可靠:

  • EF Core 查询:用 ToListAsync(cancellationToken)AsAsyncEnumerable() + 手动 await foreach,token 由上下文自动传播
  • 自定义生成器:在 async IAsyncEnumerable 方法签名中直接接收 CancellationToken,并在每个 await 后显式检查(token.ThrowIfCancellationRequested()
  • HttpClient 流式响应:用 GetStreamAsync(uri, cancellationToken) 获取流,再用 Stream.ReadAsync 传同一 token

真正容易被忽略的是:即使用了 WithCancellation,如果枚举器已经进入下一个 MoveNextAsync 调用但尚未 await,取消信号可能要等到下一次 await 才生效——这不是 bug,而是异步状态机的固有延迟。

相关专题

更多
数据分析工具有哪些
数据分析工具有哪些

数据分析工具有Excel、SQL、Python、R、Tableau、Power BI、SAS、SPSS和MATLAB等。详细介绍:1、Excel,具有强大的计算和数据处理功能;2、SQL,可以进行数据查询、过滤、排序、聚合等操作;3、Python,拥有丰富的数据分析库;4、R,拥有丰富的统计分析库和图形库;5、Tableau,提供了直观易用的用户界面等等。

685

2023.10.12

SQL中distinct的用法
SQL中distinct的用法

SQL中distinct的语法是“SELECT DISTINCT column1, column2,...,FROM table_name;”。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

323

2023.10.27

SQL中months_between使用方法
SQL中months_between使用方法

在SQL中,MONTHS_BETWEEN 是一个常见的函数,用于计算两个日期之间的月份差。想了解更多SQL的相关内容,可以阅读本专题下面的文章。

348

2024.02.23

SQL出现5120错误解决方法
SQL出现5120错误解决方法

SQL Server错误5120是由于没有足够的权限来访问或操作指定的数据库或文件引起的。想了解更多sql错误的相关内容,可以阅读本专题下面的文章。

1117

2024.03.06

sql procedure语法错误解决方法
sql procedure语法错误解决方法

sql procedure语法错误解决办法:1、仔细检查错误消息;2、检查语法规则;3、检查括号和引号;4、检查变量和参数;5、检查关键字和函数;6、逐步调试;7、参考文档和示例。想了解更多语法错误的相关内容,可以阅读本专题下面的文章。

359

2024.03.06

oracle数据库运行sql方法
oracle数据库运行sql方法

运行sql步骤包括:打开sql plus工具并连接到数据库。在提示符下输入sql语句。按enter键运行该语句。查看结果,错误消息或退出sql plus。想了解更多oracle数据库的相关内容,可以阅读本专题下面的文章。

717

2024.04.07

sql中where的含义
sql中where的含义

sql中where子句用于从表中过滤数据,它基于指定条件选择特定的行。想了解更多where的相关内容,可以阅读本专题下面的文章。

577

2024.04.29

sql中删除表的语句是什么
sql中删除表的语句是什么

sql中用于删除表的语句是drop table。语法为drop table table_name;该语句将永久删除指定表的表和数据。想了解更多sql的相关内容,可以阅读本专题下面的文章。

419

2024.04.29

C++ 高级模板编程与元编程
C++ 高级模板编程与元编程

本专题深入讲解 C++ 中的高级模板编程与元编程技术,涵盖模板特化、SFINAE、模板递归、类型萃取、编译时常量与计算、C++17 的折叠表达式与变长模板参数等。通过多个实际示例,帮助开发者掌握 如何利用 C++ 模板机制编写高效、可扩展的通用代码,并提升代码的灵活性与性能。

2

2026.01.23

热门下载

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

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
10分钟--Midjourney创作自己的漫画
10分钟--Midjourney创作自己的漫画

共1课时 | 0.1万人学习

Midjourney 关键词系列整合
Midjourney 关键词系列整合

共13课时 | 0.9万人学习

AI绘画教程
AI绘画教程

共2课时 | 0.2万人学习

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

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