.NET 中,Task 类提供了一种异步编程模型,可以用来运行异步操作。Task 类有两个方法 RunSynchronously 和 Start,它们可以用来启动任务,但它们的行为有所不同。本文主要介绍一下,.NET中通过Task的RunSynchronously()方法同步运行任务,及RunSynchronously()与Start()使用区别。

RunSynchronously():在当前任务调度程序上同步运行任务。

RunSynchronously(TaskScheduler):在提供的任务调度程序上同步运行任务。

Start():启动任务,将其调度到当前任务调度程序执行。

Start(TaskScheduler):启动任务,将其调度到指定的任务调度程序执行。

RunSynchronously请求调度器同步运行它,但是调度器很可能忽略这个提示,在线程池线程中运行它,您当前的线程将会同步阻塞,直到它完成为止。

调度程序不需要在当前线程上运行它,也不需要立即运行它,尽管我认为这将发生在公共调度程序(ThreadPoolTaskScheduler和公共UI调度程序)上。

如果任务已经启动或已经完成/出现故障,RunSynchronously还会抛出异常(不能在异步方法上使用它)。

WaitResult根本不运行任务,它们只是在当前线程上等待任务完成并阻塞它直到完成,所以如果我们想要比较,我们可以比较StartRunSynchronously来同步运行:

通过下面代码看一下RunSynchronously()和Start()的使用与区别

class Scheduler : TaskScheduler
{
    protected override void QueueTask(Task task) => 
        Console.WriteLine("QueueTask");

    //当执行该函数时,程序正在尝试以同步的方式执行Task代码
    protected override bool TryExecuteTaskInline(Task task, bool taskWasPreviouslyQueued)
    {
        Console.WriteLine("TryExecuteTaskInline");
        return false;
    }
    protected override IEnumerable<Task> GetScheduledTasks() => throw new NotImplementedException();
}
static class Program
{
    static void Main()
    {
        var taskToStart = new Task(() => { });
        var taskToRunSynchronously = new Task(() => { });
        taskToStart.Start(new Scheduler());
        taskToRunSynchronously.RunSynchronously(new Scheduler());
    }
}

Start()尝试并将任务排队到调度程序,而RunSynchronously()将尝试并内联执行它,如果失败(返回false),它将只是排队。

推荐文档