Partilhar via


out (modificador genérico) (Referência C#)

Para parâmetros de tipo genéricos, a out palavra-chave especifica que o parâmetro type é covariante. Você pode usar a out palavra-chave em interfaces genéricas e delegados.

A covariância permite que você use um tipo mais derivado do que o especificado pelo parâmetro genérico. Isso permite a conversão implícita de classes que implementam interfaces covariantes e a conversão implícita de tipos delegados. Covariância e contravariância são suportadas para tipos de referência, mas não são suportadas para tipos de valor.

Uma interface que tem um parâmetro de tipo covariante permite que seus métodos retornem mais tipos derivados do que aqueles especificados pelo parâmetro type. Por exemplo, como no .NET Framework 4, em IEnumerable<T>, o tipo T é covariante, você pode atribuir um objeto do IEnumerable(Of String) tipo a um objeto do tipo sem usar nenhum método de IEnumerable(Of Object) conversão especial.

Um delegado covariante pode ser atribuído a outro delegado do mesmo tipo, mas com um parâmetro de tipo genérico mais derivado.

Para obter mais informações, consulte Covariância e contravariância.

Exemplo - interface genérica covariante

O exemplo a seguir mostra como declarar, estender e implementar uma interface genérica covariante. Ele também mostra como usar a conversão implícita para classes que implementam uma interface 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;
    }
}

Em uma interface genérica, um parâmetro type pode ser declarado covariante se satisfizer as seguintes condições:

  • O parâmetro type é usado apenas como um tipo de retorno de métodos de interface e não usado como um tipo de argumentos de método.

    Nota

    Há uma exceção a esta regra. Se em uma interface covariante você tiver um delegado genérico contravariante como um parâmetro de método, você pode usar o tipo covariante como um parâmetro de tipo genérico para esse delegado. Para obter mais informações sobre delegados genéricos covariantes e contravariantes, consulte Variância em delegados e Usando variância para delegados genéricos de ação e func.

  • O parâmetro type não é usado como uma restrição genérica para os métodos de interface.

Exemplo - delegado genérico covariante

O exemplo a seguir mostra como declarar, instanciar e invocar um delegado genérico covariante. Ele também mostra como converter implicitamente tipos delegados.

// 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();
}

Em um delegado genérico, um tipo pode ser declarado covariante se for usado apenas como um tipo de retorno de método e não usado para argumentos de método.

Especificação da linguagem C#

Para obter mais informações, consulte a Especificação da linguagem C#. A especificação da linguagem é a fonte definitiva para a sintaxe e o uso do C#.

Consulte também