Action<T1,T2> Action<T1,T2> Action<T1,T2> Action<T1,T2> Delegate

Définition

Encapsule une méthode ayant deux paramètres et ne retournant aucune valeur.Encapsulates a method that has two parameters and does not return a value.

generic <typename T1, typename T2>
public delegate void Action(T1 arg1, T2 arg2);
public delegate void Action<in T1,in T2>(T1 arg1, T2 arg2);
type Action<'T1, 'T2> = delegate of 'T1 * 'T2 -> unit
Public Delegate Sub Action(Of In T1, In T2)(arg1 As T1, arg2 As T2)

Paramètres de type

T1

Type du premier paramètre de la méthode encapsulée par ce délégué.The type of the first parameter of the method that this delegate encapsulates.

T2

Type du deuxième paramètre de la méthode encapsulée par ce délégué.The type of the second parameter of the method that this delegate encapsulates.

Paramètres

arg1

Premier paramètre de la méthode encapsulée par ce délégué.The first parameter of the method that this delegate encapsulates.

arg2

Deuxième paramètre de la méthode encapsulée par ce délégué.The second parameter of the method that this delegate encapsulates.

Héritage
Action<T1,T2>Action<T1,T2>Action<T1,T2>Action<T1,T2>

Remarques

Vous pouvez utiliser le Action<T1,T2> délégué pour passer une méthode en tant que paramètre sans déclarer explicitement un délégué personnalisé.You can use the Action<T1,T2> delegate to pass a method as a parameter without explicitly declaring a custom delegate. La méthode encapsulée doit correspondre à la signature de méthode définie par ce délégué.The encapsulated method must correspond to the method signature that is defined by this delegate. Cela signifie que la méthode encapsulée doit avoir deux paramètres qui lui sont transmis par valeur, et qu’elle ne doit pas retourner de valeur.This means that the encapsulated method must have two parameters that are both passed to it by value, and it must not return a value. (Dans C#, la méthode doit retourner void.(In C#, the method must return void. Dans Visual Basic, elle doit être définie par Sub...End SubIn Visual Basic, it must be defined by the SubEnd Sub composer.construct. Il peut également s’agir d’une méthode qui retourne une valeur qui est ignorée.) En général, une telle méthode est utilisée pour effectuer une opération.It can also be a method that returns a value that is ignored.) Typically, such a method is used to perform an operation.

Notes

Pour référencer une méthode ayant deux paramètres et retournant une valeur, utilisez plutôt Func<T1,T2,TResult> le délégué générique.To reference a method that has two parameters and returns a value, use the generic Func<T1,T2,TResult> delegate instead.

Lorsque vous utilisez le Action<T1,T2> délégué, vous n’avez pas à définir explicitement un délégué qui encapsule une méthode avec deux paramètres.When you use the Action<T1,T2> delegate, you do not have to explicitly define a delegate that encapsulates a method with two parameters. Par exemple, le code suivant déclare explicitement un délégué nommé ConcatStrings.For example, the following code explicitly declares a delegate named ConcatStrings. Il assigne ensuite une référence à l’une ou l’autre des deux méthodes à son instance de délégué.It then assigns a reference to either of two methods to its delegate instance. Une méthode écrit deux chaînes dans la console; le deuxième écrit deux chaînes dans un fichier.One method writes two strings to the console; the second writes two strings to a file.

using System;
using System.IO;

delegate void ConcatStrings(string string1, string string2);

public class TestDelegate
{
   public static void Main()
   {
      string message1 = "The first line of a message.";
      string message2 = "The second line of a message.";
      ConcatStrings concat;
      
      if (Environment.GetCommandLineArgs().Length > 1)
         concat = WriteToFile;
      else
         concat = WriteToConsole;
         
      concat(message1, message2);
   }
  
   private static void WriteToConsole(string string1, string string2)
   {
      Console.WriteLine("{0}\n{1}", string1, string2);            
   }

   private static void WriteToFile(string string1, string string2)
   {
      StreamWriter writer = null;  
      try
      {
         writer = new StreamWriter(Environment.GetCommandLineArgs()[1], false);
         writer.WriteLine("{0}\n{1}", string1, string2);
      }
      catch
      {
         Console.WriteLine("File write operation failed...");
      }
      finally
      {
         if (writer != null) writer.Close();
      }      
   }
}
Imports System.IO

Delegate Sub ConcatStrings(string1 As String, string2 As String)

Module TestDelegate
   Public Sub Main()
      
      Dim message1 As String = "The first line of a message."
      Dim message2 As String = "The second line of a message."
      Dim concat As ConcatStrings
      
      If Environment.GetCommandLineArgs().Length > 1 Then
         concat = AddressOf WriteToFile
      Else
         concat = AddressOf WriteToConsole
      End If   
      concat(message1, message2)         
   End Sub
   
   Private Sub WriteToConsole(string1 As String, string2 As String)
      Console.WriteLine("{0}{1}{2}", string1, vbCrLf, string2)
   End Sub
   
   Private Sub WriteToFile(string1 As String, string2 As String)
      Dim writer As StreamWriter = Nothing  
      Try
         writer = New StreamWriter(Environment.GetCommandLineArgs(1), False)
         writer.WriteLine("{0}{1}{2}", string1, vbCrLf, string2)
      Catch
         Console.WriteLine("File write operation failed...")
      Finally
         If writer IsNot Nothing Then writer.Close
      End Try      
   End Sub
End Module

L’exemple suivant simplifie ce code en instanciant Action<T1,T2> le délégué au lieu de définir explicitement un nouveau délégué et en lui assignant une méthode nommée.The following example simplifies this code by instantiating the Action<T1,T2> delegate instead of explicitly defining a new delegate and assigning a named method to it.

using System;
using System.IO;

public class TestAction2
{
   public static void Main()
   {
      string message1 = "The first line of a message.";
      string message2 = "The second line of a message.";
      Action<string, string> concat;
      
      if (Environment.GetCommandLineArgs().Length > 1)
         concat = WriteToFile;
      else
         concat = WriteToConsole;
         
      concat(message1, message2);
   }
  
   private static void WriteToConsole(string string1, string string2)
   {
      Console.WriteLine("{0}\n{1}", string1, string2);            
   }

   private static void WriteToFile(string string1, string string2)
   {
      StreamWriter writer = null;  
      try
      {
         writer = new StreamWriter(Environment.GetCommandLineArgs()[1], false);
         writer.WriteLine("{0}\n{1}", string1, string2);
      }
      catch
      {
         Console.WriteLine("File write operation failed...");
      }
      finally
      {
         if (writer != null) writer.Close();
      }      
   }
}
Imports System.IO

Module TestAction2
   Public Sub Main()
      
      Dim message1 As String = "The first line of a message."
      Dim message2 As String = "The second line of a message."
      Dim concat As Action(Of String, String)
      
      If Environment.GetCommandLineArgs().Length > 1 Then
         concat = AddressOf WriteToFile
      Else
         concat = AddressOf WriteToConsole
      End If   
      concat(message1, message2)         
   End Sub
   
   Private Sub WriteToConsole(string1 As String, string2 As String)
      Console.WriteLine("{0}{1}{2}", string1, vbCrLf, string2)
   End Sub
   
   Private Sub WriteToFile(string1 As String, string2 As String)
      Dim writer As StreamWriter = Nothing  
      Try
         writer = New StreamWriter(Environment.GetCommandLineArgs(1), False)
         writer.WriteLine("{0}{1}{2}", string1, vbCrLf, string2)
      Catch
         Console.WriteLine("File write operation failed...")
      Finally
         If writer IsNot Nothing Then writer.Close
      End Try      
   End Sub
End Module

Vous pouvez également utiliser le Action<T1,T2> délégué avec des méthodes anonymes dans C#, comme l’illustre l’exemple suivant.You can also use the Action<T1,T2> delegate with anonymous methods in C#, as the following example illustrates. (Pour une introduction aux méthodes anonymes, consultez méthodes anonymes.)(For an introduction to anonymous methods, see Anonymous Methods.)

using System;
using System.IO;

public class TestAnonymousMethod
{
   public static void Main()
   {
      string message1 = "The first line of a message.";
      string message2 = "The second line of a message.";
      Action<string, string> concat;
      
      if (Environment.GetCommandLineArgs().Length > 1)
         concat = delegate(string s1, string s2) { WriteToFile(s1, s2); };
      else
         concat = delegate(string s1, string s2) { WriteToConsole(s1, s2);} ;
         
      concat(message1, message2);
   }
  
   private static void WriteToConsole(string string1, string string2)
   {
      Console.WriteLine("{0}\n{1}", string1, string2);            
   }

   private static void WriteToFile(string string1, string string2)
   {
      StreamWriter writer = null;  
      try
      {
         writer = new StreamWriter(Environment.GetCommandLineArgs()[1], false);
         writer.WriteLine("{0}\n{1}", string1, string2);
      }
      catch
      {
         Console.WriteLine("File write operation failed...");
      }
      finally
      {
         if (writer != null) writer.Close();
      }      
   }
}

Vous pouvez également assigner une expression lambda Action<T1,T2> à une instance de délégué, comme l’illustre l’exemple suivant.You can also assign a lambda expression to an Action<T1,T2> delegate instance, as the following example illustrates. (Pour une présentation des expressions lambda, consultez expressions lambda.)(For an introduction to lambda expressions, see Lambda Expressions.)

using System;
using System.IO;

public class TestLambdaExpression
{
   public static void Main()
   {
      string message1 = "The first line of a message.";
      string message2 = "The second line of a message.";
      Action<string, string> concat;
      
      if (Environment.GetCommandLineArgs().Length > 1)
         concat = (s1, s2) => WriteToFile(s1, s2);
      else
         concat = (s1, s2) => WriteToConsole(s1, s2);
         
      concat(message1, message2);
   }
  
   private static void WriteToConsole(string string1, string string2)
   {
      Console.WriteLine("{0}\n{1}", string1, string2);            
   }

   private static void WriteToFile(string string1, string string2)
   {
      StreamWriter writer = null;  
      try
      {
         writer = new StreamWriter(Environment.GetCommandLineArgs()[1], false);
         writer.WriteLine("{0}\n{1}", string1, string2);
      }
      catch
      {
         Console.WriteLine("File write operation failed...");
      }
      finally
      {
         if (writer != null) writer.Close();
      }      
   }
}
Imports System.IO

Public Module TestLambdaExpression

   Public Sub Main()
      Dim message1 As String = "The first line of a message."
      Dim message2 As String = "The second line of a message."
      Dim concat As Action(Of String, String)
      
      If Environment.GetCommandLineArgs().Length > 1 Then
         concat = Sub(s1, s2) WriteToFile(s1, s2)
      Else
         concat = Sub(s1, s2) WriteToConsole(s1, s2)
      End If
         
      concat(message1, message2)
   End Sub
  
   Private Function WriteToConsole(string1 As String, string2 As String) As Integer
      Dim message As String = String.Format("{0}{1}{2}", string1, vbCrLf, string2)
      Console.WriteLine(message)
      Return message.Length
   End Function

   Private Function WriteToFile(string1 As String, string2 As String) As Integer
      Dim writer As StreamWriter = Nothing  
      Dim message As String = String.Format("{0}{1}{2}", string1, vbCrLf, string2)
      Dim charsWritten As Integer
      Try
         writer = New StreamWriter(Environment.GetCommandLineArgs()(1), False)
         writer.WriteLine(message)
      Catch
         Console.WriteLine("File write operation failed...")
      Finally
         If writer IsNot Nothing Then 
            writer.Close()
            charsWritten = message.Length
         Else
            charsWritten = 0
         End If
      End Try      
      Return charsWritten
   End Function
End Module

Méthodes d’extension

GetMethodInfo(Delegate) GetMethodInfo(Delegate) GetMethodInfo(Delegate) GetMethodInfo(Delegate)

Obtient un objet qui représente la méthode représentée par le délégué spécifié.Gets an object that represents the method represented by the specified delegate.

S’applique à

Voir aussi