Task.Wait Method

定義

Task の実行が完了するまで待機します。 Waits for the Task to complete execution.

オーバーロード

Wait(TimeSpan)

提供された Task の実行が完了するまで、指定した時間間隔内の間、待機します。 Waits for the Task to complete execution within a specified time interval.

Wait(Int32, CancellationToken)

Task の実行が完了するまで待機します。 Waits for the Task to complete execution. タスクの完了前に、タイムアウト期間が経過するか、キャンセル トークンが取り消される場合には、待機が終了します。 The wait terminates if a timeout interval elapses or a cancellation token is canceled before the task completes.

Wait(CancellationToken)

Task の実行が完了するまで待機します。 Waits for the Task to complete execution. タスクの完了前にキャンセル トークンが取り消される場合は、待機が終了します。 The wait terminates if a cancellation token is canceled before the task completes.

Wait(Int32)

提供された Task の実行が完了するまで、指定したミリ秒数以内の間、待機します。 Waits for the Task to complete execution within a specified number of milliseconds.

Wait()

Task の実行が完了するまで待機します。 Waits for the Task to complete execution.

Wait(TimeSpan)

提供された Task の実行が完了するまで、指定した時間間隔内の間、待機します。 Waits for the Task to complete execution within a specified time interval.

public bool Wait (TimeSpan timeout);
パラメーター
timeout
TimeSpan

待機するミリ秒数を表す TimeSpan。無制限に待機する場合は、-1 ミリ秒を表す TimeSpan A TimeSpan that represents the number of milliseconds to wait, or a TimeSpan that represents -1 milliseconds to wait indefinitely.

戻り値

割り当てられた時間内に true の実行が完了した場合は Task。それ以外の場合は false true if the Task completed execution within the allotted time; otherwise, false.

例外

Task は破棄されています。 The Task has been disposed.

timeout は無限のタイムアウトを表す -1 ミリ秒以外の負の数です。 timeout is a negative number other than -1 milliseconds, which represents an infinite time-out. - または - -or- timeoutMaxValue より大きくなっています。 timeout is greater than MaxValue.

タスクが取り消されました。 The task was canceled. InnerExceptions コレクションに TaskCanceledException オブジェクトが含まれています。 The InnerExceptions collection contains a TaskCanceledException object. - または - -or- タスクの実行時に例外がスローされました。 An exception was thrown during the execution of the task. InnerExceptions コレクションには、例外に関する情報が含まれています。 The InnerExceptions collection contains information about the exception or exceptions.

次の例では、500万の 0 から 100 まで整数の乱数を生成しの平均を計算するタスクを開始します。The following example starts a task that generates five million random integers between 0 and 100 and computes their mean. この例では、Wait(TimeSpan)メソッドをアプリケーションで 150 ミリ秒以内に完了するまで待機します。The example uses the Wait(TimeSpan) method to wait for the application to complete within 150 milliseconds. アプリケーションが正常終了した場合、タスクには、それによって生成されたランダムな数値の平均と合計が表示されます。If the application completes normally, the task displays the sum and mean of the random numbers that it has generated. タイムアウト間隔が経過した場合の例は、終了前にメッセージを表示します。If the timeout interval has elapsed, the example displays a message before it terminates.

using System;
using System.Threading.Tasks;

public class Example
{
   public static void Main()
   {
      Task t = Task.Run( () => {
                            Random rnd = new Random();
                            long sum = 0;
                            int n = 5000000;
                            for (int ctr = 1; ctr <= n; ctr++) {
                               int number = rnd.Next(0, 101);
                               sum += number;
                            }
                            Console.WriteLine("Total:   {0:N0}", sum);
                            Console.WriteLine("Mean:    {0:N2}", sum/n);
                            Console.WriteLine("N:       {0:N0}", n);   
                         } );
     TimeSpan ts = TimeSpan.FromMilliseconds(150);
     if (! t.Wait(ts))
        Console.WriteLine("The timeout interval elapsed.");
   }
}
// The example displays output similar to the following:
//       Total:   50,015,714
//       Mean:    50.02
//       N:       1,000,000
// Or it displays the following output:
//      The timeout interval elapsed.
Imports System.Threading.Tasks

Module Example
   Public Sub Main()
      Dim t As Task = Task.Run( Sub()
                                   Dim rnd As New Random()
                                   Dim sum As Long
                                   Dim n As Integer = 5000000
                                   For ctr As Integer = 1 To n
                                      Dim number As Integer = rnd.Next(0, 101)
                                      sum += number
                                   Next
                                   Console.WriteLine("Total:   {0:N0}", sum)
                                   Console.WriteLine("Mean:    {0:N2}", sum/n)
                                   Console.WriteLine("N:       {0:N0}", n)   
                                End Sub)
     Dim ts As TimeSpan = TimeSpan.FromMilliseconds(150)
     If Not t.Wait(ts) Then
        Console.WriteLine("The timeout interval elapsed.")
     End If
   End Sub
End Module
' The example displays output similar to the following:
'       Total:   50,015,714
'       Mean:    50.02
'       N:       1,000,000
' Or it displays the following output:
'       The timeout interval elapsed.

注釈

Wait(TimeSpan) 現在のタスク インスタンスは次のいずれかが発生するまでに完了するを待機する呼び出し元のスレッドを同期方法を示します。Wait(TimeSpan) is a synchronization method that causes the calling thread to wait for the current task instance to complete until one of the following occurs:

  • タスクが正常に完了します。The task completes successfully.

  • タスク自体が取り消されたまたは、例外をスローします。The task itself is canceled or throws an exception. この場合、処理、AggregateException例外。In this case, you handle an AggregateException exception. AggregateException.InnerExceptionsプロパティには、例外の詳細が含まれています。The AggregateException.InnerExceptions property contains details about the exception or exceptions.

  • によって定義された間隔timeoutが経過するとします。The interval defined by timeout elapses. この場合は、現在のスレッドが実行を再開し、メソッドを返しますfalseします。In this case, the current thread resumes execution and the method returns false.

Wait(Int32, CancellationToken)

Task の実行が完了するまで待機します。 Waits for the Task to complete execution. タスクの完了前に、タイムアウト期間が経過するか、キャンセル トークンが取り消される場合には、待機が終了します。 The wait terminates if a timeout interval elapses or a cancellation token is canceled before the task completes.

public bool Wait (int millisecondsTimeout, System.Threading.CancellationToken cancellationToken);
パラメーター
millisecondsTimeout
Int32

待機するミリ秒数。無制限に待機する場合は Infinite (-1)。 The number of milliseconds to wait, or Infinite (-1) to wait indefinitely.

cancellationToken
CancellationToken

タスクの完了の待機中に観察するキャンセル トークン。 A cancellation token to observe while waiting for the task to complete.

戻り値

割り当てられた時間内に true の実行が完了した場合は Task。それ以外の場合は false true if the Task completed execution within the allotted time; otherwise, false.

例外

cancellationToken は取り消されました。 The cancellationToken was canceled.

Task は破棄されています。 The Task has been disposed.

millisecondsTimeout は無限のタイムアウトを表す -1 以外の負の数です。 millisecondsTimeout is a negative number other than -1, which represents an infinite time-out.

タスクが取り消されました。 The task was canceled. InnerExceptions コレクションに TaskCanceledException オブジェクトが含まれています。 The InnerExceptions collection contains a TaskCanceledException object. - または - -or- タスクの実行時に例外がスローされました。 An exception was thrown during the execution of the task. InnerExceptions コレクションには、例外に関する情報が含まれています。 The InnerExceptions collection contains information about the exception or exceptions.

次の例では、Wait(Int32, CancellationToken)タイムアウト値とキャンセル トークンを提供するメソッドは、タスクの完了の待機を終了できます。The following example calls the Wait(Int32, CancellationToken) method to provide both a timeout value and a cancellation token that can end the wait for a task's completion. 新しいスレッドが開始され、実行、CancelTokenメソッドでは、一時停止してから、CancellationTokenSource.Cancelキャンセル トークンをキャンセルするメソッド。A new thread is started and executes the CancelToken method, which pauses and then calls the CancellationTokenSource.Cancel method to cancel the cancellation tokens. タスクが起動し、5 秒間遅延します。A task is then launched and delays for 5 seconds. Waitメソッドが呼び出され、タスクの完了を待つし、簡単なタイムアウト値とキャンセル トークンの両方に提供されます。The Wait method is then called to wait for the task's completion and is provided both a brief timeout value and a cancellation token.

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

public class Example
{
   public static void Main()
   {
      CancellationTokenSource ts = new CancellationTokenSource();
      Thread thread = new Thread(CancelToken);
      thread.Start(ts);

      Task t = Task.Run( () => { Task.Delay(5000).Wait();
                                 Console.WriteLine("Task ended delay...");
                               });
      try {
         Console.WriteLine("About to wait completion of task {0}", t.Id);
         bool result = t.Wait(1510, ts.Token);
         Console.WriteLine("Wait completed normally: {0}", result);
         Console.WriteLine("The task status:  {0:G}", t.Status);
      }
      catch (OperationCanceledException e) {
         Console.WriteLine("{0}: The wait has been canceled. Task status: {1:G}",
                           e.GetType().Name, t.Status);
         Thread.Sleep(4000);
         Console.WriteLine("After sleeping, the task status:  {0:G}", t.Status);
         ts.Dispose();
      }
   }

   private static void CancelToken(Object obj)
   {
      Thread.Sleep(1500);
      Console.WriteLine("Canceling the cancellation token from thread {0}...",
                        Thread.CurrentThread.ManagedThreadId);
      CancellationTokenSource source = obj as CancellationTokenSource;
      if (source != null) source.Cancel();
   }
}
// The example displays output like the following if the wait is canceled by
// the cancellation token:
//    About to wait completion of task 1
//    Canceling the cancellation token from thread 3...
//    OperationCanceledException: The wait has been canceled. Task status: Running
//    Task ended delay...
//    After sleeping, the task status:  RanToCompletion
// The example displays output like the following if the wait is canceled by
// the timeout interval expiring:
//    About to wait completion of task 1
//    Wait completed normally: False
//    The task status:  Running
//    Canceling the cancellation token from thread 3...
Imports System.Threading
Imports System.Threading.Tasks

Module Example
   Public Sub Main()
      Dim ts As New CancellationTokenSource()
      Dim thread As New Thread(AddressOf CancelToken)
      thread.Start(ts)

      Dim t As Task = Task.Run( Sub()
                                   Task.Delay(5000).Wait()
                                    Console.WriteLine("Task ended delay...")
                                End Sub)
      Try
         Console.WriteLine("About to wait completion of task {0}", t.Id)
         Dim result As Boolean = t.Wait(1510, ts.Token)
         Console.WriteLine("Wait completed normally: {0}", result)
         Console.WriteLine("The task status:  {0:G}", t.Status)
      Catch e As OperationCanceledException
         Console.WriteLine("{0}: The wait has been canceled. Task status: {1:G}",
                           e.GetType().Name, t.Status)
         Thread.Sleep(4000)
         Console.WriteLine("After sleeping, the task status:  {0:G}", t.Status)
         ts.Dispose()
      End Try
   End Sub

   Private Sub CancelToken(obj As Object)
      Thread.Sleep(1500)
      Console.WriteLine("Canceling the cancellation token from thread {0}...",
                        Thread.CurrentThread.ManagedThreadId)

      If TypeOf obj Is CancellationTokenSource Then
         Dim source As CancellationTokenSource = CType(obj, CancellationTokenSource)
         source.Cancel()
      End If
   End Sub
End Module
' The example displays output like the following if the wait is canceled by
' the cancellation token:
'    About to wait completion of task 1
'    Canceling the cancellation token from thread 3...
'    OperationCanceledException: The wait has been canceled. Task status: Running
'    Task ended delay...
'    After sleeping, the task status:  RanToCompletion
' The example displays output like the following if the wait is canceled by
' the timeout interval expiring:
'    About to wait completion of task 1
'    Wait completed normally: False
'    The task status:  Running
'    Canceling the cancellation token from thread 3...

例の正確な出力に依存しているキャンセル トークンのため、待機が取り消されましたかどうか、またはタイムアウト間隔が経過したために注意してください。Note that the precise output from the example depends on whether the wait was canceled because of the cancellation token or because the timeout interval elapsed.

注釈

Wait(Int32, CancellationToken) 現在のタスク インスタンスは次のいずれかが発生するまでに完了するを待機する呼び出し元のスレッドを同期方法を示します。Wait(Int32, CancellationToken) is a synchronization method that causes the calling thread to wait for the current task instance to complete until one of the following occurs:

  • タスクが正常に完了します。The task completes successfully.

  • タスク自体が取り消されたまたは、例外をスローします。The task itself is canceled or throws an exception. この場合、処理、AggregateException例外。In this case, you handle an AggregateException exception. AggregateException.InnerExceptionsプロパティには、例外の詳細が含まれています。The AggregateException.InnerExceptions property contains details about the exception or exceptions.

  • cancellationTokenキャンセル トークンが取り消されました。The cancellationToken cancellation token is canceled. この場合、呼び出し、Wait(Int32, CancellationToken)メソッドがスローされます、OperationCanceledExceptionします。In this case, the call to the Wait(Int32, CancellationToken) method throws an OperationCanceledException.

  • によって定義された間隔millisecondsTimeoutが経過するとします。The interval defined by millisecondsTimeout elapses. この場合は、現在のスレッドが実行を再開し、メソッドを返しますfalseします。In this case, the current thread resumes execution and the method returns false.

注意

キャンセル、cancellationTokenキャンセル トークンも何も起こりませんの実行中のタスクがキャンセル トークンが渡されたも、キャンセルを処理する準備がない場合。Canceling the cancellationToken cancellation token has no effect on the running task unless it has also been passed the cancellation token and is prepared to handle cancellation. 渡す、cancellationTokenこのメソッドにオブジェクトだけになりますをキャンセルできる待機に基づいていくつかの条件にします。Passing the cancellationToken object to this method simply allows the wait to be canceled based on some condition.

Wait(CancellationToken)

Task の実行が完了するまで待機します。 Waits for the Task to complete execution. タスクの完了前にキャンセル トークンが取り消される場合は、待機が終了します。 The wait terminates if a cancellation token is canceled before the task completes.

public void Wait (System.Threading.CancellationToken cancellationToken);
パラメーター
cancellationToken
CancellationToken

タスクの完了の待機中に観察するキャンセル トークン。 A cancellation token to observe while waiting for the task to complete.

例外

cancellationToken は取り消されました。 The cancellationToken was canceled.

タスクが破棄されました。 The task has been disposed.

タスクが取り消されました。 The task was canceled. InnerExceptions コレクションに TaskCanceledException オブジェクトが含まれています。 The InnerExceptions collection contains a TaskCanceledException object. - または - -or- タスクの実行時に例外がスローされました。 An exception was thrown during the execution of the task. InnerExceptions コレクションには、例外に関する情報が含まれています。 The InnerExceptions collection contains information about the exception or exceptions.

次の例は、タスクの完了の待機をキャンセルするキャンセル トークンの簡単な使用を示しています。The following example illustrates the simple use of a cancellation token to cancel waiting for a task's completion. タスクの起動は、呼び出しのCancellationTokenSource.Cancelを 5 秒間キャンセル トークン ソースのキャンセル トークン、および、遅延のいずれかのメソッド。A task is launched, calls the CancellationTokenSource.Cancel method to cancel any of the token source's cancellation tokens, and then delays for five seconds. タスク自体がキャンセル トークンが渡されていないと、取り消し可能でないことに注意してください。Note that the task itself has not been passed the cancellation token and is not cancelable. アプリケーション スレッドの呼び出し、タスクのTask.Wait、キャンセル トークンが取り消された後に、タスクを完了するまで待機するメソッドが、待機が取り消されたOperationCanceledExceptionがスローされます。The application thread calls the task's Task.Wait method to wait for the task to complete, but the wait is canceled once the cancellation token is cancelled and an OperationCanceledException is thrown. 例外ハンドラーは、例外を報告し、6 秒間スリープしています。The exception handler reports the exception and then sleeps for six seconds. その遅延によりで完了するタスク、例の出力が示すように、RanToCompletion状態。As the output from the example shows, that delay allows the task to complete in the RanToCompletion state.

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

public class Example
{
   public static void Main()
   {
      CancellationTokenSource ts = new CancellationTokenSource();

      Task t = Task.Run( () => { Console.WriteLine("Calling Cancel...");
                                 ts.Cancel();
                                 Task.Delay(5000).Wait();
                                 Console.WriteLine("Task ended delay...");
                               });
      try {
         Console.WriteLine("About to wait for the task to complete...");
         t.Wait(ts.Token);
      }
      catch (OperationCanceledException e) {
         Console.WriteLine("{0}: The wait has been canceled. Task status: {1:G}",
                           e.GetType().Name, t.Status);
         Thread.Sleep(6000);
         Console.WriteLine("After sleeping, the task status:  {0:G}", t.Status);
      }
      ts.Dispose();
   }
}
// The example displays output like the following:
//    About to wait for the task to complete...
//    Calling Cancel...
//    OperationCanceledException: The wait has been canceled. Task status: Running
//    Task ended delay...
//    After sleeping, the task status:  RanToCompletion
Imports System.Threading
Imports System.Threading.Tasks

Module Example
   Public Sub Main()
      Dim ts As New CancellationTokenSource()

      Dim t = Task.Run( Sub()
                           Console.WriteLine("Calling Cancel...")
                           ts.Cancel()
                           Task.Delay(5000).Wait()
                           Console.WriteLine("Task ended delay...")
                        End Sub)
      Try
         Console.WriteLine("About to wait for the task to complete...")
         t.Wait(ts.Token)
      Catch e As OperationCanceledException
         Console.WriteLine("{0}: The wait has been canceled. Task status: {1:G}",
                           e.GetType().Name, t.Status)
         Thread.Sleep(6000)
         Console.WriteLine("After sleeping, the task status:  {0:G}", t.Status)
      End Try
      ts.Dispose()
   End Sub
End Module
' The example displays output like the following:
'    About to wait for the task to complete...
'    Calling Cancel...
'    OperationCanceledException: The wait has been canceled. Task status: Running
'    Task ended delay...
'    After sleeping, the task status:  RanToCompletion

注釈

Wait(CancellationToken)メソッドがキャンセル可能な待機を作成します。 これは、次のいずれかが発生するまで待機する、現在のスレッドが発生します。The Wait(CancellationToken) method creates a cancelable wait; that is, it causes the current thread to wait until one of the following occurs:

注意

キャンセル、cancellationTokenキャンセル トークンも何も起こりませんの実行中のタスクがキャンセル トークンが渡されたも、キャンセルを処理する準備がない場合。Canceling the cancellationToken cancellation token has no effect on the running task unless it has also been passed the cancellation token and is prepared to handle cancellation. 渡す、cancellationTokenオブジェクトをこのメソッドは、待機が取り消さだけになります。Passing the cancellationToken object to this method simply allows the wait to be canceled.

Wait(Int32)

提供された Task の実行が完了するまで、指定したミリ秒数以内の間、待機します。 Waits for the Task to complete execution within a specified number of milliseconds.

public bool Wait (int millisecondsTimeout);
パラメーター
millisecondsTimeout
Int32

待機するミリ秒数。無制限に待機する場合は Infinite (-1)。 The number of milliseconds to wait, or Infinite (-1) to wait indefinitely.

戻り値

割り当てられた時間内に true の実行が完了した場合は Task。それ以外の場合は false true if the Task completed execution within the allotted time; otherwise, false.

例外

Task は破棄されています。 The Task has been disposed.

millisecondsTimeout は無限のタイムアウトを表す -1 以外の負の数です。 millisecondsTimeout is a negative number other than -1, which represents an infinite time-out.

タスクが取り消されました。 The task was canceled. InnerExceptions コレクションに TaskCanceledException オブジェクトが含まれています。 The InnerExceptions collection contains a TaskCanceledException object. - または - -or- タスクの実行時に例外がスローされました。 An exception was thrown during the execution of the task. InnerExceptions コレクションには、例外に関する情報が含まれています。 The InnerExceptions collection contains information about the exception or exceptions.

次の例では、500万の 0 から 100 まで整数の乱数を生成しの平均を計算するタスクを開始します。The following example starts a task that generates five million random integers between 0 and 100 and computes their mean. この例では、Wait(Int32)メソッドをアプリケーションで 150 ミリ秒以内に完了するまで待機します。The example uses the Wait(Int32) method to wait for the application to complete within 150 milliseconds. アプリケーションが正常終了した場合、タスクには、それによって生成されたランダムな数値の平均と合計が表示されます。If the application completes normally, the task displays the sum and mean of the random numbers that it has generated. タイムアウト間隔が経過した場合の例は、終了前にメッセージを表示します。If the timeout interval has elapsed, the example displays a message before it terminates.

using System;
using System.Threading.Tasks;

public class Example
{
   public static void Main()
   {
      Task t = Task.Run( () => {
                            Random rnd = new Random();
                            long sum = 0;
                            int n = 5000000;
                            for (int ctr = 1; ctr <= n; ctr++) {
                               int number = rnd.Next(0, 101);
                               sum += number;
                            }
                            Console.WriteLine("Total:   {0:N0}", sum);
                            Console.WriteLine("Mean:    {0:N2}", sum/n);
                            Console.WriteLine("N:       {0:N0}", n);   
                         } );
     if (! t.Wait(150))
        Console.WriteLine("The timeout interval elapsed.");
   }
}
// The example displays output similar to the following:
//       Total:   50,015,714
//       Mean:    50.02
//       N:       1,000,000
// Or it displays the following output:
//      The timeout interval elapsed.
Imports System.Threading.Tasks

Module Example
   Public Sub Main()
      Dim t As Task = Task.Run( Sub()
                                   Dim rnd As New Random()
                                   Dim sum As Long
                                   Dim n As Integer = 5000000
                                   For ctr As Integer = 1 To n
                                      Dim number As Integer = rnd.Next(0, 101)
                                      sum += number
                                   Next
                                   Console.WriteLine("Total:   {0:N0}", sum)
                                   Console.WriteLine("Mean:    {0:N2}", sum/n)
                                   Console.WriteLine("N:       {0:N0}", n)   
                                End Sub)
     If Not t.Wait(150) Then
        Console.WriteLine("The timeout interval elapsed.")
     End If
   End Sub
End Module
' The example displays output similar to the following:
'       Total:   50,015,714
'       Mean:    50.02
'       N:       1,000,000
' Or it displays the following output:
'       The timeout interval elapsed.

注釈

Wait(Int32) 現在のタスク インスタンスは次のいずれかが発生するまでに完了するを待機する呼び出し元のスレッドを同期方法を示します。Wait(Int32) is a synchronization method that causes the calling thread to wait for the current task instance to complete until one of the following occurs:

  • タスクが正常に完了します。The task completes successfully.

  • タスク自体が取り消されたまたは、例外をスローします。The task itself is canceled or throws an exception. この場合、処理、AggregateException例外。In this case, you handle an AggregateException exception. AggregateException.InnerExceptionsプロパティには、例外の詳細が含まれています。The AggregateException.InnerExceptions property contains details about the exception or exceptions.

  • によって定義された間隔millisecondsTimeoutが経過するとします。The interval defined by millisecondsTimeout elapses. この場合は、現在のスレッドが実行を再開し、メソッドを返しますfalseします。In this case, the current thread resumes execution and the method returns false.

Wait()

Task の実行が完了するまで待機します。 Waits for the Task to complete execution.

public void Wait ();
例外

Task は破棄されています。 The Task has been disposed.

タスクが取り消されました。 The task was canceled. InnerExceptions コレクションに TaskCanceledException オブジェクトが含まれています。 The InnerExceptions collection contains a TaskCanceledException object. - または - -or- タスクの実行時に例外がスローされました。 An exception was thrown during the execution of the task. InnerExceptions コレクションには、例外に関する情報が含まれています。 The InnerExceptions collection contains information about the exception or exceptions.

次の例では、100万の 0 から 100 まで整数の乱数を生成しの平均を計算するタスクを開始します。The following example starts a task that generates one million random integers between 0 and 100 and computes their mean. この例では、Waitメソッドをアプリケーションが終了する前に、タスクが完了したことを確認します。The example uses the Wait method to ensure that the task completes before the application terminates. それ以外の場合、これは、コンソール アプリケーションであるため、例では、終了が終了前に、タスクを計算して、平均値を表示できます。Otherwise, because this is a console application, the example would terminate before the task can compute and display the mean.

using System;
using System.Threading.Tasks;

public class Example
{
   public static void Main()
   {
      Task t = Task.Run( () => {
                            Random rnd = new Random();
                            long sum = 0;
                            int n = 1000000;
                            for (int ctr = 1; ctr <= n; ctr++) {
                               int number = rnd.Next(0, 101);
                               sum += number;
                            }
                            Console.WriteLine("Total:   {0:N0}", sum);
                            Console.WriteLine("Mean:    {0:N2}", sum/n);
                            Console.WriteLine("N:       {0:N0}", n);   
                         } );
     t.Wait();
   }
}
// The example displays output similar to the following:
//       Total:   50,015,714
//       Mean:    50.02
//       N:       1,000,000
Imports System.Threading.Tasks

Module Example
   Public Sub Main()
      Dim t As Task = Task.Run( Sub()
                                   Dim rnd As New Random()
                                   Dim sum As Long
                                   Dim n As Integer = 1000000
                                   For ctr As Integer = 1 To n
                                      Dim number As Integer = rnd.Next(0, 101)
                                      sum += number
                                   Next
                                   Console.WriteLine("Total:   {0:N0}", sum)
                                   Console.WriteLine("Mean:    {0:N2}", sum/n)
                                   Console.WriteLine("N:       {0:N0}", n)   
                                End Sub)
     t.Wait()
   End Sub
End Module
' The example displays output similar to the following:
'       Total:   50,015,714
'       Mean:    50.02
'       N:       1,000,000

注釈

Wait 現在のタスクが完了するまで待機する呼び出し元のスレッド同期メソッドです。Wait is a synchronization method that causes the calling thread to wait until the current task has completed. 現在のタスクが実行を開始していない場合、Wait メソッドは、スケジューラのタスクを削除し、現在のスレッドでインライン実行を試みます。If the current task has not started execution, the Wait method attempts to remove the task from the scheduler and execute it inline on the current thread. 行うことがない場合、または現在のタスクが既に実行を開始した場合は、タスクが完了するまで、呼び出し元のスレッドをブロックします。If it is unable to do that, or if the current task has already started execution, it blocks the calling thread until the task completes. 詳細については、次を参照してください。 Task.Wait と"インライン" .NET ブログでの並列プログラミングにします。For more information, see Task.Wait and "Inlining" in the Parallel Programming with .NET blog.

詳細と例では、次を参照してください。方法: 1 つまたは複数のタスクが完了するまで待機します。For more information and an example, see How to: Wait on One or More Tasks to Complete.

適用対象