Parallel.Invoke メソッド
定義
重要
一部の情報は、リリース前に大きく変更される可能性があるプレリリースされた製品に関するものです。 Microsoft は、ここに記載されている情報について、明示または黙示を問わず、一切保証しません。
指定された各アクション (場合によっては並列で) を実行します。
オーバーロード
| 名前 | 説明 |
|---|---|
| Invoke(Action[]) |
指定された各アクション (場合によっては並列で) を実行します。 |
| Invoke(ParallelOptions, Action[]) |
ユーザーが操作を取り消さない限り、指定された各アクションを並列で実行します。 |
Invoke(Action[])
- ソース:
- Parallel.cs
- ソース:
- Parallel.cs
- ソース:
- Parallel.cs
- ソース:
- Parallel.cs
- ソース:
- Parallel.cs
指定された各アクション (場合によっては並列で) を実行します。
public:
static void Invoke(... cli::array <Action ^> ^ actions);
public static void Invoke(params Action[] actions);
static member Invoke : Action[] -> unit
Public Shared Sub Invoke (ParamArray actions As Action())
パラメーター
例外
actions引数はnull。
actions配列内のアクションが例外をスローするとスローされる例外。
actions配列には、null要素が含まれています。
例
この例では、 Invoke メソッドを他のメソッド、匿名デリゲート、ラムダ式と共に使用する方法を示します。
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Threading;
using System.Threading.Tasks;
class ParallelInvokeDemo
{
// Demonstrated features:
// Parallel.Invoke()
// Expected results:
// The threads on which each task gets executed may be different.
// The thread assignments may be different in different executions.
// The tasks may get executed in any order.
// Documentation:
// http://msdn.microsoft.com/library/dd783942(VS.100).aspx
static void Main()
{
try
{
Parallel.Invoke(
BasicAction, // Param #0 - static method
() => // Param #1 - lambda expression
{
Console.WriteLine("Method=beta, Thread={0}", Thread.CurrentThread.ManagedThreadId);
},
delegate() // Param #2 - in-line delegate
{
Console.WriteLine("Method=gamma, Thread={0}", Thread.CurrentThread.ManagedThreadId);
}
);
}
// No exception is expected in this example, but if one is still thrown from a task,
// it will be wrapped in AggregateException and propagated to the main thread.
catch (AggregateException e)
{
Console.WriteLine("An action has thrown an exception. THIS WAS UNEXPECTED.\n{0}", e.InnerException.ToString());
}
}
static void BasicAction()
{
Console.WriteLine("Method=alpha, Thread={0}", Thread.CurrentThread.ManagedThreadId);
}
}
Imports System.Threading
Imports System.Threading.Tasks
Module InvokeDemo
' Demonstrated features:
' Parallel.Invoke()
' Expected results:
' The threads on which each task gets executed may be different.
' The thread assignments may be different in different executions.
' The tasks may get executed in any order.
' Documentation:
' http://msdn.microsoft.com/library/dd783942(VS.100).aspx
Private Sub Main()
Try
' Param #0 - static method
Parallel.Invoke(AddressOf BasicAction,
Sub()
' Param #1 - lambda expression
Console.WriteLine("Method=beta, Thread={0}", Thread.CurrentThread.ManagedThreadId)
End Sub,
Sub()
' Param #2 - in-line delegate
Console.WriteLine("Method=gamma, Thread={0}", Thread.CurrentThread.ManagedThreadId)
End Sub)
Catch e As AggregateException
' No exception is expected in this example, but if one is still thrown from a task,
' it will be wrapped in AggregateException and propagated to the main thread.
Console.WriteLine("An action has thrown an exception. THIS WAS UNEXPECTED." & vbLf & "{0}", e.InnerException.ToString())
End Try
End Sub
Private Sub BasicAction()
Console.WriteLine("Method=alpha, Thread={0}", Thread.CurrentThread.ManagedThreadId)
End Sub
End Module
注釈
このメソッドは、一連の操作を並列で実行するために使用できます。
操作が実行される順序や、操作が並列で実行されるかどうかについては、保証されません。 このメソッドは、正常終了または例外終了によって完了が発生したかどうかに関係なく、指定された各操作が完了するまで戻りません。
詳細については、「方法: Parallel.Invoke を使用して並列操作を実行する」を参照してください。
適用対象
Invoke(ParallelOptions, Action[])
- ソース:
- Parallel.cs
- ソース:
- Parallel.cs
- ソース:
- Parallel.cs
- ソース:
- Parallel.cs
- ソース:
- Parallel.cs
ユーザーが操作を取り消さない限り、指定された各アクションを並列で実行します。
public:
static void Invoke(System::Threading::Tasks::ParallelOptions ^ parallelOptions, ... cli::array <Action ^> ^ actions);
public static void Invoke(System.Threading.Tasks.ParallelOptions parallelOptions, params Action[] actions);
static member Invoke : System.Threading.Tasks.ParallelOptions * Action[] -> unit
Public Shared Sub Invoke (parallelOptions As ParallelOptions, ParamArray actions As Action())
パラメーター
- parallelOptions
- ParallelOptions
この操作の動作を構成するオブジェクト。
- actions
- Action[]
実行するアクションの配列。
例外
CancellationToken内のparallelOptionsが設定されます。
actions配列内のアクションが例外をスローするとスローされる例外。
actions配列には、null要素が含まれています。
CancellationTokenSource内のCancellationTokenに関連付けられているparallelOptionsが破棄されました。
注釈
このメソッドは、一連の操作を並列で実行するために使用できます。 ParallelOptions構造体で渡されたキャンセル トークンを使用すると、呼び出し元は操作全体を取り消すことができます。 詳細については、「 マネージド スレッドでの取り消し」を参照してください。
操作が実行される順序や、操作が並列で実行されるかどうかについては、保証されません。 このメソッドは、正常終了または例外終了によって完了が発生したかどうかに関係なく、指定された各操作が完了するまで戻りません。
詳細については、「方法: Parallel.Invoke を使用して並列操作を実行する」を参照してください。