c#中使用Task

可以先看前面的backgroudwork文章,再看Thread文章,本demo接着Thread的环境继续。

本demo演示的是:

Task有三种写法,喜欢那种就选择那种。

并且在Task中进行停止,暂停,继续的功能。

开始。

1.界面业务说明,label1是加法计算,分别有3个功能,对label1停止加法,暂停加法,继续加法。100 是减法计算。

2.load中加载Task

第一种写法用new

   var task1 = new Task(() =>
            {
                A();

            });
            task1.Start();

            var task2 = new Task(() =>
            {
                B();

            });
            task2.Start();

第二种写法用StartNew

Task t1 = Task.Factory.StartNew(() => {
                A();
            });
            Task t2 = Task.Factory.StartNew(() => {
                B();
            });

第三种写法用Run

Task t1 = Task.Run(() =>
            {
                A();
            });


            Task t2 = Task.Run(() =>
            {
                B();
            });

也可以不写赋值变量,直接运行

Task.Run(() =>
            {
                A();
            });

Task.Run(() =>
            {
                B();
            });

3.下面是 A  B方法

 public void A()
        {
            for (int i = 0; i < 100; i++)
            {
                Thread.Sleep(1000);
                Invoke(new Action(() => label1.Text = i.ToString()));
            }

        }

        public void B()
        {
            for (int i = 0; i < 100; i++)
            {
                Thread.Sleep(1000);
                Invoke(new Action(() => label2.Text = (Convert.ToInt16(label2.Text) - 1).ToString()));
            }

        }

 以上代码复制进去,可以进行独立的运行。

在Task中进行停止,暂停,继续的功能。停止后是不能继续的。

停止按钮的代码

先声明变量token和resetEvent

        CancellationToken token;
        ManualResetEvent resetEvent = new ManualResetEvent(true);

停止按钮的代码

var tokenSource = new CancellationTokenSource();
            token = tokenSource.Token;
            tokenSource.Cancel();

 暂停按钮的代码

 resetEvent.Reset();

继续按钮的代码

resetEvent.Set();

 A方法

    public void A()
        {
            for (int i = 0; i < 100; i++)
            {
                if (token.IsCancellationRequested)//这个是加法停止的判断
                {
                    return;
                }
                resetEvent.WaitOne();//相当于把resetEvent和线程task1进行绑定
                Thread.Sleep(1000);
                Invoke(new Action(() => label1.Text = i.ToString()));
            }

        }

token.IsCancellationRequested是加法停止的判断

resetEvent.WaitOne();//相当于把resetEvent和线程task1进行“绑定”,从而可以控制线程task1

方法B不变

 public void B()
        {
            for (int i = 0; i < 100; i++)
            {
                Thread.Sleep(1000);
                Invoke(new Action(() => label2.Text = (Convert.ToInt16(label2.Text) - 1).ToString()));
            }

        }

 load进行调用:

var task1 = new Task(() =>
            {
                A();

            }, token);//这里不写token,好像也可以
            task1.Start();

            var task2 = new Task(() =>
            {
                B();

            });
            task2.Start();

 token这里可以不写,也可以写,不清楚是不是因为 resetEvent.WaitOne();进行“绑定”过了,知道的人可以说一下哦。

效果:

代码:

using System;
using System.Collections.Generic;
using System.ComponentModel;
using System.Data;
using System.Drawing;
using System.Linq;
using System.Runtime.InteropServices;
using System.Text;
using System.Threading;
using System.Threading.Tasks;
using System.Windows.Forms;

namespace WindowsFormsApp1
{
    public partial class Form1 : Form
    {
        CancellationToken token;
        ManualResetEvent resetEvent = new ManualResetEvent(true);


        public Form1()
        {
            InitializeComponent();
        }

        private void Form1_Load(object sender, EventArgs e)
        {
            var task1 = new Task(() =>
            {
                A();

            }, token);//这里不写token,好像也可以
            task1.Start();

            var task2 = new Task(() =>
            {
                B();

            });
            task2.Start();
        }

        public void A()
        {
            for (int i = 0; i < 100; i++)
            {
                if (token.IsCancellationRequested)//这个是加法停止的判断
                {
                    return;
                }
                resetEvent.WaitOne();//相当于把resetEvent和线程task1进行绑定
                Thread.Sleep(1000);
                Invoke(new Action(() => label1.Text = i.ToString()));
            }

        }

        public void B()
        {
            for (int i = 0; i < 100; i++)
            {
                Thread.Sleep(1000);
                Invoke(new Action(() => label2.Text = (Convert.ToInt16(label2.Text) - 1).ToString()));
            }

        }

        /// <summary>
        /// 停止线程
        /// </summary>
        /// <param name="sender"></param>
        /// <param name="e"></param>
        private void button1_Click(object sender, EventArgs e)
        {
            var tokenSource = new CancellationTokenSource();
            token = tokenSource.Token;
            tokenSource.Cancel();
        }
        /// <summary>
        /// 继续
        /// </summary>
        /// <param name="sender"></param>
        /// <param name="e"></param>
        private void button2_Click(object sender, EventArgs e)
        {
            resetEvent.Set();
        }

        /// <summary>
        /// 暂停
        /// </summary>
        /// <param name="sender"></param>
        /// <param name="e"></param>
        private void button3_Click(object sender, EventArgs e)
        {
            resetEvent.Reset();
        }
    }
}

拓展

            //多个task
            Task<string> t1 = File.ReadAllTextAsync("1.txt");
            Task<string> t2= File.ReadAllTextAsync("1.txt");
            Task<string> t3 = File.ReadAllTextAsync("1.txt");
            string[] t = await Task.WhenAll(t1, t2, t3);

Task.Factory.StartNew比Task.Run有更多的参数选择项,偶尔也需要根据实际场景选择Task.Factory.StartNew,但是Task.Run的用法比较简介,已经可以满足大多数的场景

 await Task.Run(A);
 await Task.Factory.StartNew(A, TaskCreationOptions.LongRunning);

 private void A()
 {

 }

 

来源:c#中使用Task_c# new task_故里2130的博客-CSDN博客

  • 7
    点赞
  • 39
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 9
    评论
C#Task是一个非常强大的多线程编程工具,它可以让开发者更方便地进行异步编程。下面是Task的详细使用方法: 1. 创建Task对象 Task有多种创建方式,其最常用的是使用静态方法Task.Factory.StartNew。 ```csharp Task task = Task.Factory.StartNew(() => { //执行异步操作 }); ``` 这里传递给StartNew方法的是一个委托,该委托包含了异步操作的代码。 2. 获取Task执行结果 在Task执行完成后,我们需要获取其执行结果。Task提供了几种方式来获取执行结果,最常用的是使用Task.Result属性。如果Task执行过程发生了异常,需要使用Task.Exception属性来获取异常信息。 ```csharp Task<int> task = Task.Factory.StartNew(() => { //执行异步操作 return 1; }); int result = task.Result; ``` 这里Task的泛型参数指定了返回值类型,如果异步操作没有返回值,可以使用Task.Factory.StartNew(Action)方法来创建Task对象。 3. 等待Task执行完成 在某些情况下,我们需要等待Task执行完成后再进行后续操作。Task提供了几种等待方式,最常用的是使用Task.Wait方法。 ```csharp Task task = Task.Factory.StartNew(() => { //执行异步操作 }); task.Wait(); ``` 这里调用Task.Wait方法会阻塞当前线程,直到Task执行完成。 4. 处理Task执行结果 在Task执行完成后,我们需要处理其执行结果。Task提供了ContinueWith方法,可以让我们在Task执行完成后执行一些操作。 ```csharp Task<int> task = Task.Factory.StartNew(() => { //执行异步操作 return 1; }); task.ContinueWith(t => { //处理Task执行结果 int result = t.Result; }); ``` 这里传递给ContinueWith方法的是一个委托,该委托包含了Task执行完成后需要执行的代码。 以上就是Task的一些常用使用方法,利用Task可以更方便地进行异步编程。需要注意的是,在使用Task时需要注意线程安全问题。
评论 9
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

故里2130

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值