Ler em inglês

Compartilhar via


Type.IsNotPublic Propriedade

Definição

Obtém um valor que indica se o Type não está declarado como público.

C#
public bool IsNotPublic { get; }

Valor da propriedade

Boolean

true se o Type não for declarado público e não for um tipo aninhado; caso contrário, false .

Implementações

Exemplos

Este exemplo usa a IsNotPublic propriedade para obter a visibilidade do tipo.

C#
using System;
using System.IO;
using System.Reflection;

class Example
{
    public static void Main()
    {
        // Get the Type and MemberInfo.
        Type t = Type.GetType("System.IO.File");
        MemberInfo[] members = t.GetMembers();
        // Get and display the DeclaringType method.
        Console.WriteLine("\nThere are {0} members in {1}.",
                          members.Length, t.FullName);
        Console.WriteLine("Is {0} non-public? {1}",
                          t.FullName, t.IsNotPublic);
    }
}
// The example displays output like the following:
//       There are 60 members in System.IO.File.
//       Is System.IO.File non-public? False

O exemplo de código a seguir demonstra por que você não pode usar IsPublic e IsNotPublic para classes aninhadas.

C#
public class A
{
    public class B { }
    private class C { }
}

Para classes aninhadas, ignore os resultados de IsPublic e e preste atenção apenas aos resultados de e IsNotPublic IsNestedPublic IsNestedPrivate . A saída de reflexão para esse fragmento de código seria a seguinte:

Classe Isnotpublic IsPublic Isnestedpublic Isnestedprivate
Um FALSE TRUE FALSE FALSE
B FALSE FALSE TRUE FALSE
C FALSE FALSE FALSE TRUE

Comentários

Não use essa propriedade com tipos aninhados; use a IsNestedPublic propriedade em vez disso.

Se o atual Type representar um parâmetro de tipo de um tipo genérico, essa propriedade retornará false .

Aplica-se a

Produto Versões
.NET Core 2.0, Core 2.1, Core 2.2, Core 3.0, Core 3.1, 5, 6, 7
.NET Framework 1.1, 2.0, 3.0, 3.5, 4.0, 4.5, 4.5.1, 4.5.2, 4.6, 4.6.1, 4.6.2, 4.7, 4.7.1, 4.7.2, 4.8
.NET Standard 2.0, 2.1

Confira também