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#.