C#编程,异步中的等待处理Task.Delay

本文详细探讨了Task.Delay和Thread.Sleep在异步编程中的区别和使用场景。Task.Delay是异步延迟,不会阻塞线程,可取消,适合于高并发环境。Thread.Sleep则是同步延迟,会阻塞线程,无法取消。通过实例代码展示了Task.Delay在带await和不带await使用时的不同效果,强调了在异步操作中使用Task.Delay的推荐性。
摘要由CSDN通过智能技术生成

一、总结

1.Task.Delay实质是创建一个任务,再任务中开启一个定时间,然后延时指定的时间
2.Task.Delay不和await一起使用情况,当代码遇到Task.Delay一句时,创建了了一个新的任务去执行延时去了,当前代码继续往下执行
3.Task.Delay和await一起使用,当代码遇到await Task.Delay时候,当前线程要等该行代码执行完成后,再继续执行后面的代码

4、Thread.Sleep 是同步延迟,Task.Delay异步延迟。
5、Thread.Sleep 会阻塞线程,Task.Delay不会。
6、Thread.Sleep不能取消,Task.Delay可以。
7、Task.Delay() 比 Thread.Sleep() 消耗更多的资源,但是Task.Delay()可用于为方法返回Task类型;或者根据CancellationToken取消标记动态取消等待
8、Task.Delay() 实质创建一个运行给定时间的任务, Thread.Sleep() 使当前线程休眠给定时间。

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

namespace _006__Task.Delay
{
    public partial class Form1 : Form
    {
        public Form1()
        {
            InitializeComponent();
        }

        private void btnDelayNoAwait_Click(object sender, EventArgs e)
        {
            Task task = Task.Factory.StartNew(() =>
            {
                Console.WriteLine($" Task.Delay开始:{DateTime.Now.ToString(" HH:mm:ss.fff")}");
                for (int i = 0; i < 10; i++)
                {
                    Console.WriteLine($" {DateTime.Now.ToString("HH:mm:ss.fff")} 正在进行:{i}");
                    Task.Delay(2000);
                }
                Console.WriteLine($" Task.Delay结束:{DateTime.Now.ToString("HH:mm:ss.fff")}");
                Console.ReadKey();
            });

        }

        private void btnDelayHaveAwait_Click(object sender, EventArgs e)
        {
            Task task = Task.Factory.StartNew(async () =>
            {
                Console.WriteLine($" Task.Delay 有await 开始:{DateTime.Now.ToString("HH:mm:ss.fff")}");
                for (int i = 0; i < 10; i++)
                {
                    Console.WriteLine($" {DateTime.Now.ToString("HH:mm:ss.fff")} 有await正在进行:{i}");
                    await Task.Delay(2000);
                }
                Console.WriteLine($" Task.Delay 有await 结束:{DateTime.Now.ToString("HH:mm:ss.fff")}");
                Console.ReadKey();
            });
        }

        private void btnThreadSleep_Click(object sender, EventArgs e)
        {
            Task task = Task.Factory.StartNew(() =>
           {
               Console.WriteLine($" Task.Delay 有await 开始:{DateTime.Now.ToString("HH:mm:ss.fff")}");
               for (int i = 0; i < 10; i++)
               {
                   Console.WriteLine($" {DateTime.Now.ToString("HH:mm:ss.fff")} 有await正在进行:{i}");
                   Thread.Sleep(2000);
               }
               Console.WriteLine($" Task.Delay 有await 结束:{DateTime.Now.ToString("HH:mm:ss.fff")}");
               Console.ReadKey();
           });
        }
    }
}

按钮【Task.Delay(不带await)】执行结果:

当程序遇到 Task.Delay(2000);时候,程序创建一个新的任务去执行延时2000了,当前任务继续向下执行,所以看起来并没有延时2秒的现象。

例如:你只有先写完作业,然后才能看电视。但是到写作业的时候,你让其他人帮你写(开启新的任务去执行延时),你继续去看电视(继续当前任务)。

按钮【Task.Delay(带await)】执行结果(推荐):

当程序遇到 await Task.Delay(2000);时候,当前任务,要等到新创建的任务执行完延时2000后,才继续后面的代码
例如:你只有先写完作业,然后才能看电视。但是到写作业的时候,你mother在旁边看着你,直到你写完作业(开启新的任务去执行延时),你才可以继续去看电视(继续当前任务)。

按钮【Thread.Sleep()】执行结果(不推荐):

Thread.Sleep 是让当前线程休眠指定的时间。在异步中是不推荐使用Thread.Sleep 的。
因为Task.Delay 多开一个线程所以消耗更多,然而实际使用中一般用Task.Delay,因为高并发不希望线程堵塞,而且Task.Delay 可以取消

原文链接:https://www.cnblogs.com/dfcq/p/12685872.html

  • 8
    点赞
  • 41
    收藏
    觉得还不错? 一键收藏
  • 3
    评论
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值