我的编程空间,编程开发者的网络收藏夹
学习永远不晚

.Net如何使用Cancellation Framework取消并行任务

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

.Net如何使用Cancellation Framework取消并行任务

本篇内容介绍了“.Net如何使用Cancellation Framework取消并行任务”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!

在.net 4.0中,引入了一个新的类CancellationToken,这个类基本上集成了我们各种常用的取消方式,在并发任务中非常有用。

同步模式下的取消:

一种比较常见的需要支持取消功能的的是一些比较耗时的分段操作:如视频转换,网络下载等,这种方式下的取消机制如下:

  • 建立一个标记位,表示该操作是否已经取消

  • UI线程在获取到取消事件后,置标记位为true

  • 耗时的操作线程里,没进行一小段操作之后查询该标记位,如果为true则主动退出。

使用方式如下:

    EventHandler externalEvent;    void Example1()    {        CancellationTokenSource cts = new CancellationTokenSource();        externalEvent +=         (sender, obj) => { cts.Cancel(); }; //wire up an external requester         try        {            int val = LongRunningFunc(cts.Token);        }        catch (OperationCanceledException)        {            //cleanup after cancellation if required...         }    }    private static int LongRunningFunc(CancellationToken token)    {        int total = 0;        for (int i = 0; i < 1000; i++)        {            for (int j = 0; j < 1000; j++)            {                total++;            }            if (token.IsCancellationRequested)            { // observe cancellation                 throw new OperationCanceledException(token); // acknowledge cancellation             }        }        return total;    }

异步模式下的取消

另外一种常见的方式是在一些异步操作中,往往不能主动释放,只能等待异步操作回调的时候才能操作结果。此时一般取消方法如下:

  • 任务线程注册异步操作完成的回调函数,开始异步操作。

  • UI线程接受取消指令,置取消标记位,并主动执行回调函数

  • 回调函数中通过取消标记位判断该任务是已经完成还是被取消的,并执行相关析构操作。

使用方式如下:

    void BlockingOperation(CancellationToken token)    {        ManualResetEvent mre = new ManualResetEvent(false);        //register a callback that will set the MRE         CancellationTokenRegistration registration =         token.Register(() => mre.Set());        using (registration)        {            mre.WaitOne();            if (token.IsCancellationRequested) //did cancellation wake us?                 throw new OperationCanceledException(token);        } //dispose the registration, which performs the deregisteration.     }

这里我们通过CancellationToken注册了一个回调方法以通知任务等待线程,也可以以我们经常使用的WaitHandle的那样的方式使用。

    void Wait(WaitHandle wh, CancellationToken token)    {        WaitHandle.WaitAny(new[] { wh, token.WaitHandle });        if (token.IsCancellationRequested) //did cancellation wake us?             throw new OperationCanceledException(token);    }

高级应用

由于例子比较简单,这里就只列举一下代码,不多介绍了。

一个CancellationToken对应多个任务

    void Example4()    {        CancellationTokenSource cts = new CancellationTokenSource();        Func1(cts.Token);        Func2(cts.Token);        Func3(cts.Token);        //...         cts.Cancel(); // all listeners see the same cancellation request.     }

一个任务对应多个CancellationToken

    void LinkingExample(CancellationToken ct1, CancellationToken ct2)    {        CancellationTokenSource linkedCTS =        CancellationTokenSource.CreateLinkedTokenSource(ct1, ct2);        try        {            SlowFunc(linkedCTS.Token);        }        catch (OperationCanceledException oce)        {            if (ct1.IsCancellationRequested)            {                // ...             }            else if (ct2.IsCancellationRequested)            {                // ...             }        }        linkedCTS.Dispose(); // clean up the linking. required.     }

最后我们再来一个并发查询时取消的例子:

    private void RunQuery()    {        int[] data = { 1, 2, 3 };        CancellationTokenSource cts = new CancellationTokenSource();        var query = data.AsParallel()                     .WithCancellation(cts.Token) // token given to library code                      .Select((x) => SlowFunc(x, cts.Token)); // token passed to user code     }    private int SlowFunc(int x, CancellationToken token)     {         int result         while(...)         {             if (token.IsCancellationRequested)             throw new OperationCanceledException(token);             ...         }         return result;     }

“.Net如何使用Cancellation Framework取消并行任务”的内容就介绍到这里了,感谢大家的阅读。如果想了解更多行业相关的知识可以关注编程网网站,小编将为大家输出更多高质量的实用文章!

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

.Net如何使用Cancellation Framework取消并行任务

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

.Net如何使用Cancellation Framework取消并行任务

本篇内容介绍了“.Net如何使用Cancellation Framework取消并行任务”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!在.n
2023-07-02

win11如何取消合并任务栏

要取消任务栏的合并,您可以按照以下步骤进行操作:1. 右键单击任务栏上的空白区域,然后选择“任务栏设置”。2. 在弹出的设置窗口中,找到“多个显示屏幕”部分。3. 找到“在多个显示屏幕上显示任务栏的按钮”选项,并将其关闭。4. 关闭后,任务
2023-08-31

如何理解.NET 4并行编程中Task的取消

如何理解.NET 4并行编程中Task的取消,很多新手对此不是很清楚,为了帮助大家解决这个难题,下面小编将为大家详细讲解,有这方面需求的人可以来学习下,希望你能有所收获。因为Task是.NET 4并行编程最为核心的一个类,也我们在是在并行编
2023-06-17

在Go语言中如何处理并发任务取消问题

在Go语言中处理并发任务取消问题,可以使用context包来管理和取消任务。首先,使用context包创建一个上下文对象,例如:```ctx, cancel := context.WithCancel(context.Background(
2023-10-09

在Go语言中如何处理并发任务取消问题?

在Go语言中如何处理并发任务取消问题?Go语言作为一门并发编程语言,提供了丰富的并发编程特性,例如goroutine和channel,使得处理并发任务变得非常方便。然而,当涉及到取消并发任务时,我们也需要特殊的机制来保证任务的安全退出。本文
2023-10-22

如何使用Python中的多线程进行任务并发执行

如何使用Python中的多线程进行任务并发执行多线程是一种常用的并发编程技术,可以提高程序的执行效率。在Python中,使用多线程可以实现任务的并发执行,从而加快程序的运行速度。本文将介绍如何使用Python中的多线程进行任务的并发执行,并
2023-10-22

Pandas中怎么使用MultiIndex选择并提取任何行和列

这篇文章主要介绍“Pandas中怎么使用MultiIndex选择并提取任何行和列”,在日常操作中,相信很多人在Pandas中怎么使用MultiIndex选择并提取任何行和列问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对
2023-07-05

C#中如何使用异步任务和并行计算技术

C#中如何使用异步任务和并行计算技术引言:在当今的软件开发中,效率和性能问题是一直被开发者关注的重点。为了提高应用程序的响应速度和完成复杂任务的效率,C#中提供了异步任务和并行计算技术。本文将详细介绍C#中如何使用异步任务和并行计算技术,并
2023-10-22

如何使用Go WaitGroup处理并发任务

在 Go 中使用 `sync.WaitGroup` 来处理并发任务,可以确保在所有任务完成之前等待主程序的执行。下面是一个简单的例子:```gopackage mainimport ("fmt""sync")func main() {var
2023-10-09

.NET Core如何使用CZGL.SystemInfo库获取主机运行资源

今天就跟大家聊聊有关.NET Core如何使用CZGL.SystemInfo库获取主机运行资源,可能很多人都不太了解,为了让大家更加了解,小编给大家总结了以下内容,希望大家根据这篇文章可以有所收获。简介CZGL.SystemInfo 是一个
2023-06-28

如何使用Systemd和Crontab在Linux系统中实现任务的并行执行

要在Linux系统中实现任务的并行执行,可以结合使用Systemd和Crontab。下面是使用这两个工具的步骤:1. 创建并行执行的任务脚本:编写任务脚本,例如 `task1.sh` 和 `task2.sh`。2. 创建 Systemd 服
2023-10-09

C#中如何使用异步任务和并发编程模型

C#中如何使用异步任务和并发编程模型,需要具体代码示例在C#编程语言中,异步任务和并发编程模型是非常重要的概念和技巧。它们可以帮助我们更好地利用计算资源,提高程序的性能和响应能力。本文将介绍C#中如何使用异步任务和并发编程模型,并提供具体的
2023-10-22

C#中如何使用并发编程模型处理异步任务

C#中如何使用并发编程模型处理异步任务,需要具体代码示例引言:在日常的软件开发中,处理异步任务是非常常见的需求。在C#中,我们可以使用并发编程模型来处理异步任务,提高程序的性能和响应能力。本文将介绍C#中的并发编程模型以及如何使用它来处理异
2023-10-22

如何在Linux系统中使用Systemd和Crontab实现任务的串行执行

要在Linux系统中使用Systemd和Crontab实现任务的串行执行,可以按照以下步骤进行操作:1. 创建一个Systemd服务单元:创建一个新的.service文件(可以使用任何文本编辑器),例如`my-service.service
2023-10-09

编程热搜

  • Python 学习之路 - Python
    一、安装Python34Windows在Python官网(https://www.python.org/downloads/)下载安装包并安装。Python的默认安装路径是:C:\Python34配置环境变量:【右键计算机】--》【属性】-
    Python 学习之路 - Python
  • chatgpt的中文全称是什么
    chatgpt的中文全称是生成型预训练变换模型。ChatGPT是什么ChatGPT是美国人工智能研究实验室OpenAI开发的一种全新聊天机器人模型,它能够通过学习和理解人类的语言来进行对话,还能根据聊天的上下文进行互动,并协助人类完成一系列
    chatgpt的中文全称是什么
  • C/C++中extern函数使用详解
  • C/C++可变参数的使用
    可变参数的使用方法远远不止以下几种,不过在C,C++中使用可变参数时要小心,在使用printf()等函数时传入的参数个数一定不能比前面的格式化字符串中的’%’符号个数少,否则会产生访问越界,运气不好的话还会导致程序崩溃
    C/C++可变参数的使用
  • css样式文件该放在哪里
  • php中数组下标必须是连续的吗
  • Python 3 教程
    Python 3 教程 Python 的 3.0 版本,常被称为 Python 3000,或简称 Py3k。相对于 Python 的早期版本,这是一个较大的升级。为了不带入过多的累赘,Python 3.0 在设计的时候没有考虑向下兼容。 Python
    Python 3 教程
  • Python pip包管理
    一、前言    在Python中, 安装第三方模块是通过 setuptools 这个工具完成的。 Python有两个封装了 setuptools的包管理工具: easy_install  和  pip , 目前官方推荐使用 pip。    
    Python pip包管理
  • ubuntu如何重新编译内核
  • 改善Java代码之慎用java动态编译

目录