Sdílet prostřednictvím


Task.RunSynchronously Metoda

Definice

Task Spouští synchronně na aktuálním TaskScheduler.

Přetížení

RunSynchronously()

Task Spouští synchronně na aktuálním TaskScheduler.

RunSynchronously(TaskScheduler)

Spustí synchronně Task na zadaném .TaskScheduler

RunSynchronously()

Zdroj:
Task.cs
Zdroj:
Task.cs
Zdroj:
Task.cs

Task Spouští synchronně na aktuálním TaskScheduler.

public:
 void RunSynchronously();
public void RunSynchronously ();
member this.RunSynchronously : unit -> unit
Public Sub RunSynchronously ()

Výjimky

Instance Task byla odstraněna.

Není Task v platném stavu pro spuštění. Je možné, že už byla spuštěna, spuštěna nebo zrušena nebo byla vytvořena způsobem, který nepodporuje přímé plánování.

Příklady

Následující příklad porovnává úlohu spuštěnou voláním RunSynchronously metody s jednou spuštěnou asynchronně. V obou případech úlohy spustí identické výrazy lambda, které zobrazují ID úlohy a ID vlákna, na kterém je úloha spuštěna. Úkol vypočítá součet celých čísel mezi 1 a 1 000 000. Jak ukazuje výstup z příkladu, úloha spuštěná voláním RunSynchronously metody běží ve vlákně aplikace, zatímco asynchronní úloha ne.

using System;
using System.Threading;
using System.Threading.Tasks;

public class Example
{
   public static void Main()
   {
      Console.WriteLine("Application executing on thread {0}",
                        Thread.CurrentThread.ManagedThreadId);
      var asyncTask = Task.Run( () => {  Console.WriteLine("Task {0} (asyncTask) executing on Thread {1}",
                                                           Task.CurrentId,
                                                           Thread.CurrentThread.ManagedThreadId);
                                         long sum = 0;
                                         for (int ctr = 1; ctr <= 1000000; ctr++ )
                                            sum += ctr;
                                         return sum;
                                      });
      var syncTask = new Task<long>( () =>  { Console.WriteLine("Task {0} (syncTask) executing on Thread {1}",
                                                                 Task.CurrentId,
                                                                 Thread.CurrentThread.ManagedThreadId);
                                              long sum = 0;
                                              for (int ctr = 1; ctr <= 1000000; ctr++ )
                                                 sum += ctr;
                                              return sum;
                                            });
      syncTask.RunSynchronously();
      Console.WriteLine();
      Console.WriteLine("Task {0} returned {1:N0}", syncTask.Id, syncTask.Result);
      Console.WriteLine("Task {0} returned {1:N0}", asyncTask.Id, asyncTask.Result);
   }
}
// The example displays the following output:
//       Application executing on thread 1
//       Task 1 (syncTask) executing on Thread 1
//       Task 2 (asyncTask) executing on Thread 3
//       1 status: RanToCompletion
//       2 status: RanToCompletion
//
//       Task 2 returned 500,000,500,000
//       Task 1 returned 500,000,500,000
open System
open System.Threading
open System.Threading.Tasks

printfn $"Application executing on thread {Thread.CurrentThread.ManagedThreadId}"

let asyncTask =
    Task.Run(fun () ->
        printfn $"Task {Task.CurrentId} (asyncTask) executing on Thread {Thread.CurrentThread.ManagedThreadId}"
        let mutable sum = 0L

        for i = 1 to 1000000 do
            sum <- sum + int64 i

        sum)

let syncTask =
    new Task<int64>(fun () ->
        printfn $"Task {Task.CurrentId} (syncTask) executing on Thread {Thread.CurrentThread.ManagedThreadId}"
        let mutable sum = 0L

        for i = 1 to 1000000 do
            sum <- sum + int64 i

        sum)

syncTask.RunSynchronously()
printfn $"\nTask {syncTask.Id} returned {syncTask.Result:N0}"
printfn $"Task {asyncTask.Id} returned {asyncTask.Result:N0}"

// The example displays the following output:
//       Application executing on thread 1
//       Task 1 (syncTask) executing on Thread 1
//       Task 2 (asyncTask) executing on Thread 3
//       1 status: RanToCompletion
//       2 status: RanToCompletion
//
//       Task 2 returned 500,000,500,000
//       Task 1 returned 500,000,500,000
Imports System.Threading
Imports System.Threading.Tasks

Module Example
   Public Sub Main()
      Console.WriteLine("Application executing on thread {0}",
                        Thread.CurrentThread.ManagedThreadId)
      Dim asyncTask = Task.Run( Function()
                                   Console.WriteLine("Task {0} (asyncTask) executing on Thread {1}",
                                                     Task.CurrentId,
                                                     Thread.CurrentThread.ManagedThreadId)
                                   Dim sum As Long = 0
                                   For ctr As Integer = 1 To 1000000
                                      sum += ctr
                                   Next
                                   Return sum
                                End Function)
      Dim syncTask As New Task(Of Long)( Function()
                                            Console.WriteLine("Task {0} (syncTask) executing on Thread {1}",
                                                              Task.CurrentId,
                                                              Thread.CurrentThread.ManagedThreadId)
                                            Dim sum As Long = 0
                                            For ctr As Integer = 1 To 1000000
                                               sum += ctr
                                            Next
                                            Return sum
                                         End Function)
      syncTask.RunSynchronously()
      Console.WriteLine()
      Console.WriteLine("Task {0} returned {1:N0}", syncTask.Id, syncTask.Result)
      Console.WriteLine("Task {0} returned {1:N0}", asyncTask.Id, asyncTask.Result)
   End Sub
End Module
' The example displays the following output:
'       Application executing on thread 1
'       Task 1 (syncTask) executing on Thread 1
'       Task 2 (asyncTask) executing on Thread 3
'       1 status: RanToCompletion
'       2 status: RanToCompletion
'
'       Task 2 returned 500,000,500,000
'       Task 1 returned 500,000,500,000

Poznámky

Úlohy se obvykle provádějí asynchronně ve vlákně fondu vláken a neblokují volající vlákno. Úlohy spuštěné voláním RunSynchronously() metody jsou přidruženy k aktuálnímu TaskScheduler a jsou spuštěny ve volajícím vlákně. Pokud cílový plánovač nepodporuje spuštění této úlohy ve volajícím vlákně, bude úloha naplánována na spuštění v plánovači a volající vlákno bude blokováno, dokud úloha nedokončí provádění. I když úloha běží synchronně, volající vlákno by stále mělo volat Wait , aby zvládlo všechny výjimky, které by úloha mohla vyvolat. Další informace o zpracování výjimek najdete v tématu Zpracování výjimek.

Úlohy prováděné voláním RunSynchronously metody se vytvoří voláním konstruktoru Task třídy nebo Task<TResult> . Úloha, která se má spustit synchronně, musí být ve stavu .Created Úloha může být spuštěna a spuštěna pouze jednou. Jakýkoli pokus o naplánování úkolu podruhé způsobí výjimku.

Viz také

Platí pro

RunSynchronously(TaskScheduler)

Zdroj:
Task.cs
Zdroj:
Task.cs
Zdroj:
Task.cs

Spustí synchronně Task na zadaném .TaskScheduler

public:
 void RunSynchronously(System::Threading::Tasks::TaskScheduler ^ scheduler);
public void RunSynchronously (System.Threading.Tasks.TaskScheduler scheduler);
member this.RunSynchronously : System.Threading.Tasks.TaskScheduler -> unit
Public Sub RunSynchronously (scheduler As TaskScheduler)

Parametry

scheduler
TaskScheduler

Plánovač, ve kterém se chcete pokusit spustit tuto úlohu vloženou.

Výjimky

Instance Task byla odstraněna.

Argument scheduler je null.

Není Task v platném stavu pro spuštění. Je možné, že už byla spuštěna, spuštěna nebo zrušena nebo byla vytvořena způsobem, který nepodporuje přímé plánování.

Poznámky

Úlohy prováděné voláním RunSynchronously metody se vytvoří voláním konstruktoru Task třídy nebo Task<TResult> . Úloha, která se má spustit synchronně, musí být ve stavu .Created Úloha může být spuštěna a spuštěna pouze jednou. Jakýkoli pokus o naplánování úkolu podruhé způsobí výjimku.

Pokud cílový plánovač nepodporuje spuštění této úlohy v aktuálním vlákně, bude úloha naplánována na spuštění v plánovači a aktuální vlákno bude blokováno, dokud úloha nedokončí provádění. Z tohoto důvodu volající vlákno nemusí volat metodu, jako Wait je, aby se zajistilo, že úloha dokončila provádění. Další informace o zpracování výjimek pro operace úloh najdete v tématu Zpracování výjimek.

Viz také

Platí pro