C#学习笔记-Task.Delay和Thread.Sleep的区别

当我们在代码中的调用await Task.Delay(x),我们并不是在指示程序"此处暂停x毫秒",而是在说:"我已经完成了我能做的所有工作,你可以去运行其他任务了,x毫秒后请唤醒我继续我的工作"。这样看起来,Task.Delay并不像是一个暂停指令,而更像是一个让时间调度器知道当前任务可以被暂时挂起,而去运行其他任务的信号。

下面这个例子或许可以更明确地展示Task.Delay和Thread.Sleep的区别:

csharp 复制代码
using System;
using System.Threading;
using System.Threading.Tasks;
using ConsoleApp1;

public class Example
{
    public static void Main()
    {
        Log.Debug("主线程开始运行...");
        WorkWithDelay();
        for (int i = 0; i < 5; i++)
        {
            Thread.Sleep(1000);
            Log.Debug("主线程在做其他任务...");
        }
        Log.Debug("主线程结束运行...");
    }

    //一个使用了Task.Delay的任务
    public static async void WorkWithDelay()
    {
        Log.Debug("这个任务开始运行...");
        for (int i = 0; i < 5; i++)
        {
            //TODO:BOIL 这里测试 Task.Delay 和 Thread.Sleep差别
            await Task.Delay(1000);  
            Thread.Sleep(1000);
          
            Log.Debug("这个任务在做任务...");
        }
        Log.Debug("这个任务结束运行...");
    }
}

1、 当调用Thread.Sleep时候

Thread.Sleep(1000);

2、 当调用Task.Delay 时候

await Task.Delay(1000);

看起来 新起了个线程

相关推荐
唐青枫14 小时前
别再乱用 StartNew:C#.NET TaskFactory 任务调度实战详解
c#·.net
Artech1 天前
[MAF预定义的AIContextProvider-03]ChatHistoryMemoryProvider——赋予Agent从经验中学习的能力
ai·c#·agent·memory·maf
Scout-leaf3 天前
C#摸鱼实录——IoC与DI案例详解
c#
咕白m6253 天前
使用 C# 在 Excel 中应用多种字体样式
后端·c#
Artech3 天前
[MAF预定义的AIContextProvider-02]AgentSkillsProvider——将Agent Skills引入MAF
ai·c#·agent·agent skills·maf
2601_962072554 天前
李梦娇常识4600问|题库|打印版
sql·华为od·华为·c#·华为云·.net·harmonyos
m0_547486664 天前
《C#语言程序设计与实践》 全套PPT课件
c语言·c#·c语言程序设计
叶帆4 天前
【YFIOs】用C#开发硬件之设备上云
开发语言·unity·c#
IT方大同4 天前
(嵌入式操作系统)信号量
嵌入式硬件·c#
z落落4 天前
C# FileStream文件流读取文件
开发语言·c#