out (Modificatore generico) (Riferimenti per C#)

Per i parametri di tipo generico, la parola chiave out specifica che il parametro di tipo è covariante.È possibile utilizzare la parola chiave out in interfacce e delegati generici.

La covarianza consente di utilizzare un tipo più derivato di quello specificato dal parametro generico.Ciò consente la conversione implicita di classi che implementano interfacce variant e la conversione implicita di tipi delegati.La covarianza e la controvarianza sono supportate per i tipi di riferimento, ma non per i tipi di valore.

Un'interfaccia che dispone di un parametro di tipo covariante consente ai metodi di restituire tipi più derivati di quelli specificati dal parametro di tipo.Poiché, ad esempio, in .NET Framework 4, nell'interfaccia IEnumerable<T>, il tipo T è covariante, è possibile assegnare un oggetto del tipo IEnumerabe(Of String) a un oggetto del tipo IEnumerable(Of Object) senza utilizzare alcun metodo di conversione speciale.

A un delegato covariante può essere assegnato un altro delegato dello stesso tipo, ma con un parametro di tipo generico più derivato.

Per ulteriori informazioni, vedere Covarianza e controvarianza (C# e Visual Basic).

Esempio

Nell'esempio seguente viene illustrato come dichiarare, estendere e implementare un'interfaccia generica covariante.Viene inoltre illustrato come utilizzare la conversione implicita per le classi che implementano un'interfaccia covariante.

// Covariant interface.
interface ICovariant<out R> { }

// Extending covariant interface.
interface IExtCovariant<out R> : ICovariant<R> { }

// Implementing covariant interface.
class Sample<R> : ICovariant<R> { }

class Program
{
    static void Test()
    {
        ICovariant<Object> iobj = new Sample<Object>();
        ICovariant<String> istr = new Sample<String>();

        // You can assign istr to iobj because
        // the ICovariant interface is covariant.
        iobj = istr;
    }
}

In un'interfaccia generica, un parametro di tipo può essere dichiarato covariante se soddisfa le condizioni seguenti:

  • Il parametro di tipo viene utilizzato solo come tipo restituito di metodi di interfaccia e non viene utilizzato come tipo di argomenti del metodo.

    [!NOTA]

    Esiste un'eccezione a questa regola.Se in un'interfaccia covariante si dispone di un delegato generico controvariante come parametro del metodo, è possibile utilizzare il tipo covariante come parametro di tipo generico per questo delegato.Per ulteriori informazioni sui delegati generici covarianti e controvarianti, vedere Varianza nei delegati (C# e Visual Basic) e Utilizzo della varianza per i delegati generici Func e Action (C# e Visual Basic).

  • Il parametro di tipo non viene utilizzato come vincolo generico per i metodi di interfaccia.

Nell'esempio seguente viene illustrato come dichiarare, creare un'istanza e richiamare un delegato generico covariante.Viene inoltre illustrato come convertire in modo implicito i tipi delegati.

// Covariant delegate.
public delegate R DCovariant<out R>();

// Methods that match the delegate signature.
public static Control SampleControl()
{ return new Control(); }

public static Button SampleButton()
{ return new Button(); }

public void Test()
{            
    // Instantiate the delegates with the methods.
    DCovariant<Control> dControl = SampleControl;
    DCovariant<Button> dButton = SampleButton;

    // You can assign dButton to dControl
    // because the DCovariant delegate is covariant.
    dControl = dButton;

    // Invoke the delegate.
    dControl(); 
}

In un delegato generico, un tipo può essere dichiarato covariante se viene utilizzato solo come tipo restituito del metodo e non per gli argomenti del metodo.

Specifiche del linguaggio C#

Per ulteriori informazioni, vedere la Specifiche del linguaggio C#. La specifica del linguaggio è la fonte ufficiale per la sintassi e l'utilizzo di C#.

Vedere anche

Riferimenti

in (Modificatore generico) (Riferimenti per C#)

Modificatori (Riferimenti per C#)

Concetti

Varianza nelle interfacce generiche (C# e Visual Basic)