Partilhar via


Domínio de acessibilidade (referência de C#)

O domínio de acessibilidade de um membro especifica quais seções do programa um membro pode ser referenciado. Se o membro estiver aninhado em outro tipo, o seu domínio de acessibilidade é determinado por ambas as o nível de acessibilidade de membro e o domínio de acessibilidade do tipo imediatamente contido.

Pelo menos, o domínio de acessibilidade de um tipo de nível superior é o texto do programa do que é declarado no projeto. Ou seja, o domínio inclui todos os arquivos de origem deste projeto. Pelo menos, o domínio de acessibilidade de um tipo aninhado é o texto do programa do tipo no qual é declarada. Ou seja, o domínio é o corpo de tipo, o que inclui todos os tipos aninhados. O domínio de acessibilidade de um tipo aninhado nunca excede do tipo recipiente. Esses conceitos são demonstrados no exemplo a seguir.

Exemplo

Este exemplo contém um tipo de nível superior, T1e duas classes aninhadas, M1 e M2. As classes contêm campos que tenham diferentes acessibilidade declarada. No Main método, um comentário acompanhar cada instrução para indicar o domínio de acessibilidade de cada membro. Observe que as instruções que tentam referenciar membros inacessíveis são comentadas. Se você quiser ver os erros de compilador causados pela referência de um membro inacessível, remova os comentários de um por vez.


namespace AccessibilityDomainNamespace
{
    public class T1
    {
        public static int publicInt;
        internal static int internalInt;
        private static int privateInt = 0;
        static T1()
        {
            // T1 can access public or internal members
            // in a public or private (or internal) nested class
            M1.publicInt = 1;
            M1.internalInt = 2;
            M2.publicInt = 3;
            M2.internalInt = 4;

            // Cannot access the private member privateInt
            // in either class:
            // M1.privateInt = 2; //CS0122
        }

        public class M1
        {
            public static int publicInt;
            internal static int internalInt;
            private static int privateInt = 0;
        }

        private class M2
        {
            public static int publicInt = 0;
            internal static int internalInt = 0;
            private static int privateInt = 0;
        }
    }

    class MainClass
    {
        static void Main()
        {
            // Access is unlimited:
            T1.publicInt = 1;

            // Accessible only in current assembly:
            T1.internalInt = 2;

            // Error CS0122: inaccessible outside T1:
            // T1.privateInt = 3;  

            // Access is unlimited:
            T1.M1.publicInt = 1;

            // Accessible only in current assembly:
            T1.M1.internalInt = 2;

            // Error CS0122: inaccessible outside M1:
            //    T1.M1.privateInt = 3; 

            // Error CS0122: inaccessible outside T1:
            //    T1.M2.publicInt = 1;

            // Error CS0122: inaccessible outside T1:
            //    T1.M2.internalInt = 2;

            // Error CS0122: inaccessible outside M2:
            //    T1.M2.privateInt = 3;



            // Keep the console open in debug mode.
            System.Console.WriteLine("Press any key to exit.");
            System.Console.ReadKey();

        }
    }
}

Especificação da linguagem C#

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

Consulte também

Referência

C# Keywords

Access Modifiers (C# Reference)

Accessibility Levels (C# Reference)

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

Access Modifiers (C# Programming Guide)

public (C# Reference)

private (C# Reference)

protected (C# Reference)

internal (C# Reference)

Conceitos

C# Programming Guide

Outros recursos

C# Reference