Questo articolo è stato tradotto automaticamente. Per visualizzare l'articolo in inglese, selezionare la casella di controllo Inglese. È possibile anche visualizzare il testo inglese in una finestra popup posizionando il puntatore del mouse sopra il testo.
Traduzione
Inglese

Delegato Func<T, TResult>

 

Data di pubblicazione: ottobre 2016

Incapsula un metodo che ha un parametro e restituisce un valore del tipo specificato dal parametro TResult.

Per esaminare il codice sorgente di .NET Framework per questo tipo, vedere il Reference Source.

Spazio dei nomi:   System
Assembly:  mscorlib (in mscorlib.dll)

public delegate TResult Func<in T, out TResult>(
	T arg
)

Parametri

arg
Type: T

Parametro del metodo incapsulato da questo delegato.

Valore restituito

Type: TResult

Valore restituito del metodo incapsulato da questo delegato.

Parametri tipo

inT

Tipo del parametro del metodo incapsulato da questo delegato.

outTResult

Tipo del valore restituito del metodo incapsulato da questo delegato.

System_CAPS_noteNota

Per visualizzare il codice sorgente di .NET Framework per questo tipo, vedere il Reference Source. È possibile esplorare il codice sorgente online, scaricare i riferimenti per la visualizzazione offline e scorrere le origini (inclusi aggiornamenti e patch) durante l'esecuzione del debug. see instructions.

È possibile utilizzare questo delegato per rappresentare un metodo che può essere passato come parametro senza dichiarare in modo esplicito un delegato personalizzato. Il metodo incapsulato deve corrispondere alla firma del metodo definita da questo delegato. Ciò significa che il metodo incapsulato deve avere un parametro che viene passato per valore e che deve restituire un valore.

System_CAPS_noteNota

Per fare riferimento a un metodo che dispone di un parametro e restituisce void (o in Visual Basic, che è dichiarato come un Sub piuttosto che come un Function), utilizzare il metodo generico Action<T> delegato.

Quando si utilizza il Func<T, TResult> delegato, non è necessario definire in modo esplicito un delegato che incapsula un metodo con un singolo parametro. Ad esempio, il codice seguente dichiara in modo esplicito un delegato denominato ConvertMethod e assegna un riferimento per il UppercaseString metodo all'istanza di delegato.

using System;

delegate string ConvertMethod(string inString);

public class DelegateExample
{
   public static void Main()
   {
      // Instantiate delegate to reference UppercaseString method
      ConvertMethod convertMeth = UppercaseString;
      string name = "Dakota";
      // Use delegate instance to call UppercaseString method
      Console.WriteLine(convertMeth(name));
   }

   private static string UppercaseString(string inputString)
   {
      return inputString.ToUpper();
   }
}

Nell'esempio seguente questo codice viene semplificato creando un'istanza di Func<T, TResult> delegato anziché la definizione di un nuovo delegato e assegnarvi un metodo denominato in modo esplicito.

using System;

public class GenericFunc
{
   public static void Main()
   {
      // Instantiate delegate to reference UppercaseString method
      Func<string, string> convertMethod = UppercaseString;
      string name = "Dakota";
      // Use delegate instance to call UppercaseString method
      Console.WriteLine(convertMethod(name));
   }

   private static string UppercaseString(string inputString)
   {
      return inputString.ToUpper();
   }
}

È inoltre possibile utilizzare il Func<T, TResult> delegati con metodi anonimi di c#, come illustrato nell'esempio seguente. (Per un'introduzione ai metodi anonimi, vedere Metodi anonimi (Guida per programmatori C#).)

using System;

public class Anonymous
{
   public static void Main()
   {
      Func<string, string> convert = delegate(string s)
         { return s.ToUpper();}; 

      string name = "Dakota";
      Console.WriteLine(convert(name));   
   }
}

È inoltre possibile assegnare un'espressione lambda a un Func<T, TResult> delegato, come illustrato nell'esempio seguente. (Per un'introduzione alle espressioni lambda, vedere Lambda Expressions (Visual Basic) e Espressioni lambda (Guida per programmatori C#).)

using System;

public class LambdaExpression
{
   public static void Main()
   {
      Func<string, string> convert = s => s.ToUpper();

      string name = "Dakota";
      Console.WriteLine(convert(name));   
   }
}

Il tipo sottostante di un'espressione lambda è uno dei generica Func delegati. In questo modo possibile passare un'espressione lambda come un parametro senza assegnarla in modo esplicito un delegato. In particolare, poiché molti metodi dei tipi nel System.Linq dispone di spazio dei nomi Func<T, TResult> parametri, è possibile passare questi metodi di un'espressione lambda senza creare un'istanza in modo esplicito un Func<T, TResult> delegare.

Nell'esempio riportato di seguito viene illustrato come dichiarare e utilizzare un Func<T, TResult> delegare. In questo esempio dichiara un Func<T, TResult> variabile e assegna un'espressione lambda che converte i caratteri in una stringa in lettere maiuscole. Il delegato che incapsula questo metodo viene successivamente passato per il Enumerable.Select<TSource, TResult> metodo per modificare le stringhe in una matrice di stringhe in lettere maiuscole.

using System;
using System.Collections;
using System.Collections.Generic;
using System.Linq;

static class Func
{
   static void Main(string[] args)
   {
      // Declare a Func variable and assign a lambda expression to the  
      // variable. The method takes a string and converts it to uppercase.
      Func<string, string> selector = str => str.ToUpper();

      // Create an array of strings.
      string[] words = { "orange", "apple", "Article", "elephant" };
      // Query the array and select strings according to the selector method.
      IEnumerable<String> aWords = words.Select(selector);

      // Output the results to the console.
      foreach (String word in aWords)
         Console.WriteLine(word);
   }
}      
/*
This code example produces the following output:

   ORANGE
   APPLE
   ARTICLE
   ELEPHANT
*/

Universal Windows Platform
Disponibile da 8
.NET Framework
Disponibile da 3.5
Libreria di classi portabile
Supportato in: piattaforme .NET portabili
Silverlight
Disponibile da 2.0
Windows Phone Silverlight
Disponibile da 7.0
Windows Phone
Disponibile da 8.1
Torna all'inizio
Mostra: