新闻中心

C# 怎么使用 CancellationToken 取消异步任务_C# CancellationToken 异步任务取消教程

2025-11-03
浏览次数:
返回列表
CancellationToken用于协作取消异步任务,通过CancellationTokenSource触发取消信号,任务需主动检查并响应。典型场景包括用户取消、超时或应用关闭。传入token至支持的方法(如HttpClient.GetAsync)可实现自动取消;自定义方法则需轮询IsCancellationRequested或调用ThrowIfCancellationRequested。若取消,抛出OperationCanceledException。使用CancelAfter可设置超时自动取消,确保资源及时释放且不强制终止操作。

c# 怎么使用 cancellationtoken 取消异步任务_c# cancellationtoken 异步任务取消教程

在 C# 中,CancellationToken 是用来协作式取消异步任务的核心机制。它不能强制终止一个正在运行的操作,而是通过通知的方式让任务自行决定何时安全退出。下面详细介绍如何正确使用 CancellationToken 来取消异步操作。

什么是 CancellationToken?

CancellationToken 来自 CancellationTokenSource,它是取消请求的“信号”。当调用 CancellationTokenSource.Cancel() 时,所有关联的 token 都会进入“已取消”状态,监听该 token 的任务可以据此中断执行。

典型使用场景包括:用户点击取消按钮、超时控制、关闭应用时清理后台任务等。

基本用法:传递 CancellationToken 到异步方法

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

Musho Musho

AI网页设计Figma插件

Musho 76 查看详情 Musho
var cts = new CancellationTokenSource();
<p>// 模拟 2 秒后自动取消
// cts.CancelAfter(2000);</p><p>try
{
using var client = new HttpClient();
var response = await client.GetAsync("<a href="https://www.php.cn/link/85c19375f0c12c6793bf66b4e2666dc4">https://www.php.cn/link/85c19375f0c12c6793bf66b4e2666dc4</a>", cts.Token);
Console.WriteLine(response.StatusCode);
}
catch (OperationCanceledException)
{
Console.WriteLine("请求已被取消");
}
catch (HttpRequestException ex)
{
Console.WriteLine($"请求异常: {ex.Message}");
}</p>

如果在请求完成前调用了 cts.Cancel() 或设置了 CancelAfter,就会抛出 OperationCanceledException

在自定义异步方法中响应取消

如果你自己编写长时间运行的异步方法,需要定期检查 token 状态并主动退出。

public async Task DoWorkAsync(CancellationToken token)
{
    for (int i = 0; i < 100; i++)
    {
        // 模拟工作
        await Task.Delay(100, token); // Delay 支持 token
<pre class='brush:php;toolbar:false;'>    // 手动检查是否取消
    if (token.IsCancellationRequested)
    {
        Console.WriteLine("任务收到取消请求");
        return; // 或抛出 OperationCanceledException
    }

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

}

也可以调用 token.ThrowIfCancellationRequested() 主动抛出异常:

token.ThrowIfCancellationRequested();

组合多个 CancellationToken

有时你需要同时监听多个取消条件,比如用户取消 + 超时。可以用 CancellationTokenSource.CreateLinkedTokenSource 合并多个 token。

var userCts = new CancellationTokenSource();
var timeoutCts = new CancellationTokenSource(TimeSpan.FromSeconds(5));
<p>using var linkedCts = CancellationTokenSource.CreateLinkedTokenSource(
userCts.Token,
timeoutCts.Token);</p><p>try
{
await DoWorkAsync(linkedCts.Token);
}
catch (OperationCanceledException)
{
if (timeoutCts.IsCancellationRequested)
Console.WriteLine("超时导致取消");
else if (userCts.IsCancellationRequested)
Console.WriteLine("用户手动取消");
}</p>

只要任意一个源触发取消,链接的 token 就会变为取消状态。

基本上就这些。掌握 CancellationToken 的关键是:传递 token、及时检查、合理处理异常。只要任务配合响应,就能实现干净、可控的异步取消逻辑。

以上就是C# 怎么使用 CancellationToken 取消异步任务_C# CancellationToken 异步任务取消教程的详细内容,更多请关注其它相关文章!


# 可以用  # 廊坊校园营销推广渠道  # 马尾网络推广网站建设  # 网站建设策划目的及过程  # 泰兴网站建设内容  # 网点推广与营销步骤  # 内页seo查询  # 怎么让qq看点的营销号推广自己  # 兰州seo优化技巧代理  # 贵阳seo优化效果最好  # 池州seo排名公司  # 已被  # ai  # 就能  # 有哪些  # 游戏开发  # 如何使用  # 自定义  # 就会  # 抛出  # 多个  # c#  # 异步任务  # stream 


相关栏目: 【 科技资讯46185 】 【 网络学院92790


相关推荐: Safari怎么安装扩展程序 浏览器插件安装与管理方法【详解】  J*aScript中正确使用querySelectorAll与复杂CSS选择器  漫蛙2在线漫画入口 漫蛙正版漫画网页版直达  PyTorch模型训练准确率不提升:诊断与修复常见指标计算错误  Golang如何实现简单的Web表单_Golang表单提交与验证处理方法  机器学习中对数变换预测结果的反向还原  MinIO大规模对象列表性能瓶颈深度解析与外部元数据管理策略  vivo浏览器自带的下载器速度慢怎么办 vivo浏览器提升文件下载速度的技巧  学习通网页版官方登录 超星学习通电脑端入口指南  使用 Pandas 高效处理 .dat 文件:字符清理与数据计算  c++20的std::jthread是什么_c++可中断线程与RAII式管理  解决移动端滚动问题的overflow属性应用指南  Golang如何使用bytes.Split分割字节切片_Golang bytes切片分割方法  J*aScript中如何高效提取对象指定属性  谷歌邮箱注册显示错误Gmail服务器异常与延迟处理  mc.js游戏直达 mc.js网页免下载版本秒进地址  Sublime怎么配置Nim语言环境_Sublime Nim代码高亮与补全  sublime如何配置Go语言开发环境_sublime搭建Golang编译运行系统  163邮箱网页版入口导航平台 163邮箱网页版登录入口官网导航  Golang如何通过reflect操作map_Golang reflect map操作与遍历技巧  蛙漫官方正版入口 蛙漫网页在线全集免费观看  CSS Grid如何控制元素对齐_align-items与justify-items组合使用  韩小圈电脑版在线入口_网页版免费登录地址  如何在CSS中使用浮动制作导航栏_float实现水平菜单  Golang如何使用new_Go new分配内存机制讲解  解决 MongoDB 聚合查询中对象数组 _id 匹配问题  向日葵客户端怎么进行远程CentOS控制_向日葵客户端远程CentOS控制操作教程  在J*a中如何使用Stream.map转换元素_Stream映射操作解析  小红书怎么解除第三方平台绑定_小红书多平台登录解绑方法介绍  微信网页版扫码登录入口 微信网页版二维码登录入口  小米Civi 4录制视频过暗_小米Civi 4亮度优化  印象笔记如何设提醒任务防漏执行_印象笔记设提醒任务防漏执行【任务提醒】  天眼查怎么看公司融资情况 天眼查企业融资历史查询步骤【攻略】  QQ邮箱电脑版登录入口_QQ邮箱官方网站登录平台  Win10怎么设置静态IP地址 Win10手动配置IP地址步骤【指南】  J*aScript数组对象转换:按指定键分组与值收集  Linux如何排查内存不足OOME问题_LinuxOOM分析教程  Win10快速启动功能利弊分析 Win10开启或关闭快速启动教程【技巧】  4399免费游戏网址入口 4399小游戏免费入口点开即玩  深入理解字体排版:Adobe光学字偶距与CSS字偶距的差异与实现  uc浏览器网页版入口 uc浏览器网页版最新网址  QQ邮箱网页版入口 QQ邮箱官方邮箱登录通道  4399体育竞技小游戏_4399小游戏赛事入口  PDO预处理语句中冒号的正确处理:区分SQL函数格式与命名占位符  mc.js免安装版 mc.js一键畅玩入口  为什么我的微信朋友圈看不到别人的更新_微信朋友圈更新显示异常解决方法  J*aScript:在map操作中高效处理空数组  新手怎么开始学化妆 零基础化妆入门教程  Go Martini框架:动态服务解码后的图片内容  Win10怎么制作U盘启动盘 Win10系统安装U盘制作教程【详解】 

搜索