Partilhar via


Restrições no uso de níveis de acessibilidade (Referência C#)

Ao especificar um tipo em uma declaração, verifique se o nível de acessibilidade do tipo depende do nível de acessibilidade de um membro ou de outro tipo. Por exemplo, a classe base direta deve ser pelo menos tão acessível quanto a classe derivada. As declarações a seguir causam um erro de compilador porque a classe BaseClass base é menos acessível do que MyClass:

class BaseClass {...}
public class MyClass: BaseClass {...} // Error

A tabela a seguir resume as restrições nos níveis de acessibilidade declarados.

Contexto Observações
Classes A classe base direta de um tipo de classe deve ser pelo menos tão acessível quanto o próprio tipo de classe.
Interfaces As interfaces de base explícitas de um tipo de interface devem ser pelo menos tão acessíveis quanto o próprio tipo de interface.
Delegados O tipo de retorno e os tipos de parâmetro de um tipo de delegado devem ser pelo menos tão acessíveis quanto o próprio tipo de delegado.
Constantes O tipo de constante deve ser pelo menos tão acessível quanto a própria constante.
Campos O tipo de campo deve ser pelo menos tão acessível quanto o próprio campo.
Metodologia O tipo de retorno e os tipos de parâmetro de um método devem ser pelo menos tão acessíveis quanto o próprio método.
Propriedades O tipo de propriedade deve ser pelo menos tão acessível quanto a própria propriedade.
Eventos O tipo de evento deve ser pelo menos tão acessível quanto o próprio evento.
Indexadores Os tipos de tipo e parâmetro de um indexador devem ser pelo menos tão acessíveis quanto o próprio indexador.
Operadores O tipo de retorno e os tipos de parâmetros de um operador devem ser pelo menos tão acessíveis quanto o próprio operador.
Construtores Os tipos de parâmetros de um construtor devem ser pelo menos tão acessíveis quanto o próprio construtor.

Exemplo

O exemplo a seguir contém declarações erradas de diferentes tipos. O comentário após cada declaração indica o erro esperado do compilador.

// Restrictions on Using Accessibility Levels
// CS0052 expected as well as CS0053, CS0056, and CS0057
// To make the program work, change access level of both class B
// and MyPrivateMethod() to public.

using System;

// A delegate:
delegate int MyDelegate();

class B
{
    // A private method:
    static int MyPrivateMethod()
    {
        return 0;
    }
}

public class A
{
    // Error: The type B is less accessible than the field A.myField.
    public B myField = new B();

    // Error: The type B is less accessible
    // than the constant A.myConst.
    public readonly B myConst = new B();

    public B MyMethod()
    {
        // Error: The type B is less accessible
        // than the method A.MyMethod.
        return new B();
    }

    // Error: The type B is less accessible than the property A.MyProp
    public B MyProp
    {
        set
        {
        }
    }

    MyDelegate d = new MyDelegate(B.MyPrivateMethod);
    // Even when B is declared public, you still get the error:
    // "The parameter B.MyPrivateMethod is not accessible due to
    // protection level."

    public static B operator +(A m1, B m2)
    {
        // Error: The type B is less accessible
        // than the operator A.operator +(A,B)
        return new B();
    }

    static void Main()
    {
        Console.Write("Compiled successfully");
    }
}

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