ActionBlock<TInput> Constructors

Definitie

Overloads

Name Description
ActionBlock<TInput>(Action<TInput>)

Initialiseert een nieuw exemplaar van de ActionBlock<TInput> klasse met de opgegeven actie.

ActionBlock<TInput>(Func<TInput,Task>)

Initialiseert een nieuw exemplaar van de ActionBlock<TInput> klasse met de opgegeven actie.

ActionBlock<TInput>(Action<TInput>, ExecutionDataflowBlockOptions)

Initialiseert een nieuw exemplaar van de ActionBlock<TInput> klasse met de opgegeven actie- en configuratieopties.

ActionBlock<TInput>(Func<TInput,Task>, ExecutionDataflowBlockOptions)

Initialiseert een nieuw exemplaar van de ActionBlock<TInput> klasse met de opgegeven actie- en configuratieopties.

ActionBlock<TInput>(Action<TInput>)

Bron:
ActionBlock.cs
Bron:
ActionBlock.cs
Bron:
ActionBlock.cs
Bron:
ActionBlock.cs
Bron:
ActionBlock.cs
Bron:
ActionBlock.cs
Bron:
ActionBlock.cs

Initialiseert een nieuw exemplaar van de ActionBlock<TInput> klasse met de opgegeven actie.

public:
 ActionBlock(Action<TInput> ^ action);
public ActionBlock(Action<TInput> action);
new System.Threading.Tasks.Dataflow.ActionBlock<'Input> : Action<'Input> -> System.Threading.Tasks.Dataflow.ActionBlock<'Input>
Public Sub New (action As Action(Of TInput))

Parameters

action
Action<TInput>

De actie die moet worden aangeroepen met elk ontvangen gegevenselement.

Uitzonderingen

action is null.

Van toepassing op

ActionBlock<TInput>(Func<TInput,Task>)

Bron:
ActionBlock.cs
Bron:
ActionBlock.cs
Bron:
ActionBlock.cs
Bron:
ActionBlock.cs
Bron:
ActionBlock.cs
Bron:
ActionBlock.cs
Bron:
ActionBlock.cs

Initialiseert een nieuw exemplaar van de ActionBlock<TInput> klasse met de opgegeven actie.

public:
 ActionBlock(Func<TInput, System::Threading::Tasks::Task ^> ^ action);
public ActionBlock(Func<TInput,System.Threading.Tasks.Task> action);
new System.Threading.Tasks.Dataflow.ActionBlock<'Input> : Func<'Input, System.Threading.Tasks.Task> -> System.Threading.Tasks.Dataflow.ActionBlock<'Input>
Public Sub New (action As Func(Of TInput, Task))

Parameters

action
Func<TInput,Task>

De actie die moet worden aangeroepen met elk ontvangen gegevenselement.

Uitzonderingen

action is null.

Van toepassing op

ActionBlock<TInput>(Action<TInput>, ExecutionDataflowBlockOptions)

Bron:
ActionBlock.cs
Bron:
ActionBlock.cs
Bron:
ActionBlock.cs
Bron:
ActionBlock.cs
Bron:
ActionBlock.cs
Bron:
ActionBlock.cs
Bron:
ActionBlock.cs

Initialiseert een nieuw exemplaar van de ActionBlock<TInput> klasse met de opgegeven actie- en configuratieopties.

public:
 ActionBlock(Action<TInput> ^ action, System::Threading::Tasks::Dataflow::ExecutionDataflowBlockOptions ^ dataflowBlockOptions);
public ActionBlock(Action<TInput> action, System.Threading.Tasks.Dataflow.ExecutionDataflowBlockOptions dataflowBlockOptions);
new System.Threading.Tasks.Dataflow.ActionBlock<'Input> : Action<'Input> * System.Threading.Tasks.Dataflow.ExecutionDataflowBlockOptions -> System.Threading.Tasks.Dataflow.ActionBlock<'Input>
Public Sub New (action As Action(Of TInput), dataflowBlockOptions As ExecutionDataflowBlockOptions)

Parameters

action
Action<TInput>

De actie die moet worden aangeroepen met elk ontvangen gegevenselement.

dataflowBlockOptions
ExecutionDataflowBlockOptions

De opties waarmee u dit ActionBlock<TInput>wilt configureren.

Uitzonderingen

action is null.

– of –

dataflowBlockOptions is null.

Voorbeelden

In het volgende voorbeeld ziet u hoe u de ActionBlock<TInput>(Action<TInput>, ExecutionDataflowBlockOptions) constructor gebruikt om een nieuw ActionBlock<TInput> object te maken. Dit codevoorbeeld maakt deel uit van een groter voorbeeld dat wordt gegeven voor het onderwerp Procedure: De mate van parallelle uitvoering opgeven in een onderwerp over blokgegevensstromen .

// Performs several computations by using dataflow and returns the elapsed
// time required to perform the computations.
static TimeSpan TimeDataflowComputations(int maxDegreeOfParallelism,
   int messageCount)
{
   // Create an ActionBlock<int> that performs some work.
   var workerBlock = new ActionBlock<int>(
      // Simulate work by suspending the current thread.
      millisecondsTimeout => Thread.Sleep(millisecondsTimeout),
      // Specify a maximum degree of parallelism.
      new ExecutionDataflowBlockOptions
      {
         MaxDegreeOfParallelism = maxDegreeOfParallelism
      });

   // Compute the time that it takes for several messages to
   // flow through the dataflow block.

   Stopwatch stopwatch = new Stopwatch();
   stopwatch.Start();

   for (int i = 0; i < messageCount; i++)
   {
      workerBlock.Post(1000);
   }
   workerBlock.Complete();

   // Wait for all messages to propagate through the network.
   workerBlock.Completion.Wait();

   // Stop the timer and return the elapsed number of milliseconds.
   stopwatch.Stop();
   return stopwatch.Elapsed;
}
' Demonstrates how to specify the maximum degree of parallelism 
' when using dataflow.
Friend Class Program
   ' Performs several computations by using dataflow and returns the elapsed
   ' time required to perform the computations.
   Private Shared Function TimeDataflowComputations(ByVal maxDegreeOfParallelism As Integer, ByVal messageCount As Integer) As TimeSpan
      ' Create an ActionBlock<int> that performs some work.
      Dim workerBlock = New ActionBlock(Of Integer)(Function(millisecondsTimeout) Pause(millisecondsTimeout), New ExecutionDataflowBlockOptions() With { .MaxDegreeOfParallelism = maxDegreeOfParallelism})
         ' Simulate work by suspending the current thread.
         ' Specify a maximum degree of parallelism.

      ' Compute the time that it takes for several messages to 
      ' flow through the dataflow block.

      Dim stopwatch As New Stopwatch()
      stopwatch.Start()

      For i As Integer = 0 To messageCount - 1
         workerBlock.Post(1000)
      Next i
      workerBlock.Complete()

      ' Wait for all messages to propagate through the network.
      workerBlock.Completion.Wait()

      ' Stop the timer and return the elapsed number of milliseconds.
      stopwatch.Stop()
      Return stopwatch.Elapsed
   End Function

   Private Shared Function Pause(ByVal obj As Object)
      Thread.Sleep(obj)
      Return Nothing
   End Function

Van toepassing op

ActionBlock<TInput>(Func<TInput,Task>, ExecutionDataflowBlockOptions)

Bron:
ActionBlock.cs
Bron:
ActionBlock.cs
Bron:
ActionBlock.cs
Bron:
ActionBlock.cs
Bron:
ActionBlock.cs
Bron:
ActionBlock.cs
Bron:
ActionBlock.cs

Initialiseert een nieuw exemplaar van de ActionBlock<TInput> klasse met de opgegeven actie- en configuratieopties.

public:
 ActionBlock(Func<TInput, System::Threading::Tasks::Task ^> ^ action, System::Threading::Tasks::Dataflow::ExecutionDataflowBlockOptions ^ dataflowBlockOptions);
public ActionBlock(Func<TInput,System.Threading.Tasks.Task> action, System.Threading.Tasks.Dataflow.ExecutionDataflowBlockOptions dataflowBlockOptions);
new System.Threading.Tasks.Dataflow.ActionBlock<'Input> : Func<'Input, System.Threading.Tasks.Task> * System.Threading.Tasks.Dataflow.ExecutionDataflowBlockOptions -> System.Threading.Tasks.Dataflow.ActionBlock<'Input>
Public Sub New (action As Func(Of TInput, Task), dataflowBlockOptions As ExecutionDataflowBlockOptions)

Parameters

action
Func<TInput,Task>

De actie die moet worden aangeroepen met elk ontvangen gegevenselement.

dataflowBlockOptions
ExecutionDataflowBlockOptions

De opties waarmee u dit ActionBlock<TInput>wilt configureren.

Uitzonderingen

action is null.

– of –

dataflowBlockOptions is null.

Van toepassing op