0

0

.NET中如何使用CancellationToken取消异步操作_异步操作取消机制详解

幻夢星雲

幻夢星雲

发布时间:2025-11-23 15:43:02

|

569人浏览过

|

来源于php中文网

原创

CancellationToken是.NET中用于协作式取消异步操作的核心机制,由CancellationTokenSource创建并管理。它通过传递令牌使任务主动检查取消请求,避免强制终止线程导致的问题。关键点包括:取消为协作式、令牌只能取消一次、不能强制中断执行。常见用法有传入支持取消的异步方法(如HttpClient.GetAsync),设置超时或手动调用ThrowIfCancellationRequested()检查状态。还可通过CreateLinkedTokenSource组合多个取消条件,实现超时与用户取消等复合控制,提升应用响应性和资源利用率。

.net中如何使用cancellationtoken取消异步操作_异步操作取消机制详解

在 .NET 中,CancellationToken 是用于协作式取消异步操作的核心机制。它允许你请求取消长时间运行或可中断的任务,而任务本身决定是否以及何时响应取消请求。这种设计避免了强制终止线程带来的资源泄漏或状态不一致问题。

什么是 CancellationToken?

CancellationToken 是一个轻量级结构,表示可能发生的取消通知。它通常由 CancellationTokenSource 创建和管理。当调用 CancellationTokenSource.Cancel() 方法时,所有关联的 token 会进入“已取消”状态,并触发注册的回调函数(如果有)。

关键点:

  • 取消是协作式的 —— 异步方法必须主动检查 token 状态。
  • 一个 token 只能被取消一次,之后状态永久为“已取消”。
  • 不能强制终止正在执行的操作,只能通知其尝试停止。

如何在异步方法中使用 CancellationToken

大多数内置的异步方法(如 HttpClient.GetAsyncStreamReader.ReadLineAsync)都接受一个 CancellationToken 参数。你只需将 token 传入即可启用取消支持。

示例:使用 HttpClient 发起可取消的请求

using var cts = new CancellationTokenSource(TimeSpan.FromSeconds(5)); // 5秒后自动取消
try
{
    using var client = new HttpClient();
    var response = await client.GetAsync("https://httpbin.org/delay/10", cts.Token);
    Console.WriteLine(await response.Content.ReadAsStringAsync());
}
catch (OperationCanceledException ex)
{
    Console.WriteLine("请求被取消:" + ex.Message);
}

说明:

  • CancellationTokenSource 控制生命周期。
  • 设置超时时间后,超过该时间自动触发取消。
  • 捕获 OperationCanceledException 处理取消情形。

手动检查取消令牌

如果你编写自定义异步逻辑(如循环处理数据),需要定期检查 token 是否已被请求取消。

MaxAI
MaxAI

MaxAI.me是一款功能强大的浏览器AI插件,集成了多种AI模型。

下载

示例:模拟长时间任务并监听取消

public async Task LongRunningProcessAsync(CancellationToken token)
{
    for (int i = 0; i < 100; i++)
    {
        // 模拟工作
        await Task.Delay(100, token); // Delay 支持 token

        // 手动检查(可选)
        token.ThrowIfCancellationRequested();

        Console.WriteLine($"处理进度: {i + 1}%");
    }
}

建议做法:

  • 在每个循环迭代中检查 token。
  • 调用 ThrowIfCancellationRequested() 抛出标准异常。
  • 或将 token 传递给支持它的 API(如 Task.Delay、EF Core 查询等)。

组合多个取消条件

你可以通过 CancellationTokenSource.CreateLinkedTokenSource 合并多个 token,实现更复杂的取消策略。

例如:同时监听用户取消和超时

var cts1 = new CancellationTokenSource();
var cts2 = new CancellationTokenSource(TimeSpan.FromSeconds(3));

using var linkedCts = CancellationTokenSource.CreateLinkedTokenSource(cts1.Token, cts2.Token);

try
{
    await LongRunningProcessAsync(linkedCts.Token);
}
catch (OperationCanceledException)
{
    if (cts2.IsCancellationRequested)
        Console.WriteLine("操作因超时被取消");
    else
        Console.WriteLine("操作被用户取消");
}

这在 Web API 中很常见:客户端断开连接 + 请求超时双重控制。

基本上就这些。合理使用 CancellationToken 能显著提升应用的响应性和资源利用率,尤其是在高并发或长时间任务场景中。

相关专题

更多
登录token无效
登录token无效

登录token无效解决方法:1、检查token的有效期限,如果token已经过期,需要重新获取一个新的token;2、检查token的签名,如果签名不正确,需要重新获取一个新的token;3、检查密钥的正确性,如果密钥不正确,需要重新获取一个新的token;4、使用HTTPS协议传输token,建议使用HTTPS协议进行传输 ;5、使用双因素认证,双因素认证可以提高账户的安全性。

6080

2023.09.14

登录token无效怎么办
登录token无效怎么办

登录token无效的解决办法有检查Token是否过期、检查Token是否正确、检查Token是否被篡改、检查Token是否与用户匹配、清除缓存或Cookie、检查网络连接和服务器状态、重新登录或请求新的Token、联系技术支持或开发人员等。本专题为大家提供token相关的文章、下载、课程内容,供大家免费下载体验。

798

2023.09.14

token怎么获取
token怎么获取

获取token值的方法:1、小程序调用“wx.login()”获取 临时登录凭证code,并回传到开发者服务器;2、开发者服务器以code换取,用户唯一标识openid和会话密钥“session_key”。想了解更详细的内容,可以阅读本专题下面的文章。

1056

2023.12.21

token什么意思
token什么意思

token是一种用于表示用户权限、记录交易信息、支付虚拟货币的数字货币。可以用来在特定的网络上进行交易,用来购买或出售特定的虚拟货币,也可以用来支付特定的服务费用。想了解更多token什么意思的相关内容可以访问本专题下面的文章。

1211

2024.03.01

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

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

480

2023.08.10

Java 项目构建与依赖管理(Maven / Gradle)
Java 项目构建与依赖管理(Maven / Gradle)

本专题系统讲解 Java 项目构建与依赖管理的完整体系,重点覆盖 Maven 与 Gradle 的核心概念、项目生命周期、依赖冲突解决、多模块项目管理、构建加速与版本发布规范。通过真实项目结构示例,帮助学习者掌握 从零搭建、维护到发布 Java 工程的标准化流程,提升在实际团队开发中的工程能力与协作效率。

10

2026.01.12

c++主流开发框架汇总
c++主流开发框架汇总

本专题整合了c++开发框架推荐,阅读专题下面的文章了解更多详细内容。

106

2026.01.09

c++框架学习教程汇总
c++框架学习教程汇总

本专题整合了c++框架学习教程汇总,阅读专题下面的文章了解更多详细内容。

63

2026.01.09

学python好用的网站推荐
学python好用的网站推荐

本专题整合了python学习教程汇总,阅读专题下面的文章了解更多详细内容。

139

2026.01.09

热门下载

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

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
Django 教程
Django 教程

共28课时 | 3万人学习

Excel 教程
Excel 教程

共162课时 | 11.5万人学习

SciPy 教程
SciPy 教程

共10课时 | 1.1万人学习

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

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