Ler em inglês

Compartilhar via


Assembly Classe

Definição

Representa um assembly, que é um bloco de construção reutilizável, com controle de versão e autodescrevendo um aplicativo de common language runtime.

public abstract class Assembly
public abstract class Assembly : System.Reflection.ICustomAttributeProvider, System.Runtime.Serialization.ISerializable
public abstract class Assembly : System.Reflection.ICustomAttributeProvider
[System.Runtime.InteropServices.ClassInterface(System.Runtime.InteropServices.ClassInterfaceType.None)]
[System.Serializable]
public class Assembly : System.Reflection.ICustomAttributeProvider, System.Runtime.InteropServices._Assembly, System.Runtime.Serialization.ISerializable, System.Security.IEvidenceFactory
[System.Runtime.InteropServices.ClassInterface(System.Runtime.InteropServices.ClassInterfaceType.None)]
[System.Serializable]
[System.Runtime.InteropServices.ComVisible(true)]
public class Assembly : System.Reflection.ICustomAttributeProvider, System.Runtime.InteropServices._Assembly, System.Runtime.Serialization.ISerializable, System.Security.IEvidenceFactory
[System.Runtime.InteropServices.ClassInterface(System.Runtime.InteropServices.ClassInterfaceType.None)]
[System.Serializable]
[System.Runtime.InteropServices.ComVisible(true)]
public abstract class Assembly : System.Reflection.ICustomAttributeProvider, System.Runtime.InteropServices._Assembly, System.Runtime.Serialization.ISerializable, System.Security.IEvidenceFactory
Herança
Assembly
Derivado
Atributos
Implementações

Exemplos

O exemplo de código a seguir mostra como obter o assembly em execução no momento, criar uma instância de um tipo contido nesse assembly e invocar um dos métodos do tipo com associação tardia. Para essa finalidade, o exemplo de código define uma classe chamada Example, com um método chamado SampleMethod. O construtor da classe aceita um inteiro, que é usado para calcular o valor retornado do método.

O exemplo de código também demonstra o uso do método GetName para obter um objeto AssemblyName que pode ser usado para analisar o nome completo do assembly. O exemplo exibe o número de versão do assembly, a propriedade CodeBase e a propriedade EntryPoint.

using System;
using System.Reflection;
using System.Security.Permissions;

[assembly:AssemblyVersionAttribute("1.0.2000.0")]

public class Example
{
    private int factor;
    public Example(int f)
    {
        factor = f;
    }

    public int SampleMethod(int x)
    {
        Console.WriteLine("\nExample.SampleMethod({0}) executes.", x);
        return x * factor;
    }

    public static void Main()
    {
        Assembly assem = typeof(Example).Assembly;

        Console.WriteLine("Assembly Full Name:");
        Console.WriteLine(assem.FullName);

        // The AssemblyName type can be used to parse the full name.
        AssemblyName assemName = assem.GetName();
        Console.WriteLine("\nName: {0}", assemName.Name);
        Console.WriteLine("Version: {0}.{1}",
            assemName.Version.Major, assemName.Version.Minor);

        Console.WriteLine("\nAssembly CodeBase:");
        Console.WriteLine(assem.CodeBase);

        // Create an object from the assembly, passing in the correct number
        // and type of arguments for the constructor.
        Object o = assem.CreateInstance("Example", false,
            BindingFlags.ExactBinding,
            null, new Object[] { 2 }, null, null);

        // Make a late-bound call to an instance method of the object.
        MethodInfo m = assem.GetType("Example").GetMethod("SampleMethod");
        Object ret = m.Invoke(o, new Object[] { 42 });
        Console.WriteLine("SampleMethod returned {0}.", ret);

        Console.WriteLine("\nAssembly entry point:");
        Console.WriteLine(assem.EntryPoint);
    }
}

/* This code example produces output similar to the following:

Assembly Full Name:
source, Version=1.0.2000.0, Culture=neutral, PublicKeyToken=null

Name: source
Version: 1.0

Assembly CodeBase:
file:///C:/sdtree/AssemblyClass/cs/source.exe

Example.SampleMethod(42) executes.
SampleMethod returned 84.

Assembly entry point:
Void Main()
 */

Comentários

Use a classe Assembly para carregar assemblies, explorar os metadados e partes constituintes de assemblies, descobrir os tipos contidos em assemblies e criar instâncias desses tipos.

Para obter uma matriz de objetos Assembly que representam os assemblies atualmente carregados em um domínio de aplicativo (por exemplo, o domínio de aplicativo padrão de um projeto simples), use o método AppDomain.GetAssemblies.

Para carregar assemblies dinamicamente, a classe Assembly fornece os seguintes métodos estáticos (métodosShared no Visual Basic). Os assemblies são carregados no domínio do aplicativo em que a operação de carga ocorre.

  • A maneira recomendada de carregar assemblies é usar o método Load, que identifica o assembly a ser carregado pelo nome de exibição (por exemplo, "System.Windows.Forms, Version=2.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089"). A pesquisa do assembly segue as regras descritas em Como o Runtime localiza assemblies.

  • Os métodos ReflectionOnlyLoad e ReflectionOnlyLoadFrom permitem carregar um assembly para reflexão, mas não para execução. Por exemplo, um assembly direcionado a uma plataforma de 64 bits pode ser examinado pelo código em execução em uma plataforma de 32 bits.

  • Os métodos LoadFile e LoadFrom são fornecidos para cenários raros em que um assembly deve ser identificado por caminho.

Para obter um objeto Assembly para o assembly em execução no momento, use o método GetExecutingAssembly.

Muitos membros da classe Assembly fornecem informações sobre um assembly. Por exemplo:

  • O método GetName retorna um objeto AssemblyName que fornece acesso às partes do nome de exibição do assembly.

  • O método GetCustomAttributes lista os atributos aplicados ao assembly.

  • O método GetFiles fornece acesso aos arquivos no manifesto do assembly.

  • O método GetManifestResourceNames fornece os nomes dos recursos no manifesto do assembly.

O método GetTypes lista todos os tipos no assembly. O método GetExportedTypes lista os tipos visíveis para os chamadores fora do assembly. O método GetType pode ser usado para pesquisar um tipo específico no assembly. O método CreateInstance pode ser usado para pesquisar e criar instâncias de tipos no assembly.

Para obter mais informações sobre assemblies, consulte a seção "Domínios e assemblies de aplicativo" no tópico Domínios do Aplicativo.

Construtores

Assembly()

Inicializa uma nova instância da classe Assembly.

Propriedades

CodeBase
Obsoleto.
Obsoleto.

Obtém o local do assembly conforme especificado originalmente, por exemplo, em um objeto AssemblyName.

CustomAttributes

Obtém uma coleção que contém os atributos personalizados desse assembly.

DefinedTypes

Obtém uma coleção dos tipos definidos neste assembly.

EntryPoint

Obtém o ponto de entrada deste assembly.

EscapedCodeBase
Obsoleto.
Obsoleto.

Obtém o URI, incluindo caracteres de escape, que representa a base de código.

Evidence

Obtém a evidência deste assembly.

ExportedTypes

Obtém uma coleção dos tipos públicos definidos neste assembly que são visíveis fora do assembly.

FullName

Obtém o nome de exibição do assembly.

GlobalAssemblyCache
Obsoleto.

Obtém um valor que indica se o assembly foi carregado do cache de assembly global (somente do .NET Framework).

HostContext

Obtém o contexto do host com o qual o assembly foi carregado.

ImageRuntimeVersion

Obtém uma cadeia de caracteres que representa a versão do CLR (Common Language Runtime) salva no arquivo que contém o manifesto.

IsCollectible

Obtém um valor que indica se esse assembly é mantido em um AssemblyLoadContextcolecionável.

IsDynamic

Obtém um valor que indica se o assembly atual foi gerado dinamicamente no processo atual usando a emissão de reflexão.

IsFullyTrusted

Obtém um valor que indica se o assembly atual é carregado com confiança total.

Location

Obtém o caminho completo ou o local UNC do arquivo carregado que contém o manifesto.

ManifestModule

Obtém o módulo que contém o manifesto do assembly atual.

Modules

Obtém uma coleção que contém os módulos neste assembly.

PermissionSet

Obtém o conjunto de concessões do assembly atual.

ReflectionOnly

Obtém um valor Boolean indicando se esse assembly foi carregado no contexto somente reflexão.

SecurityRuleSet

Obtém um valor que indica qual conjunto de regras de segurança o CLR (Common Language Runtime) impõe para esse assembly.

Métodos

CreateInstance(String)

Localiza o tipo especificado desse assembly e cria uma instância dele usando o ativador do sistema, usando a pesquisa que diferencia maiúsculas de minúsculas.

CreateInstance(String, Boolean)

Localiza o tipo especificado desse assembly e cria uma instância dele usando o ativador do sistema, com pesquisa opcional que diferencia maiúsculas de minúsculas.

CreateInstance(String, Boolean, BindingFlags, Binder, Object[], CultureInfo, Object[])

Localiza o tipo especificado desse assembly e cria uma instância dele usando o ativador do sistema, com pesquisa opcional que diferencia maiúsculas de minúsculas e ter a cultura, os argumentos e os atributos de associação e ativação especificados.

CreateQualifiedName(String, String)

Cria o nome de um tipo qualificado pelo nome de exibição de seu assembly.

Equals(Object)

Determina se esse assembly e o objeto especificado são iguais.

Equals(Object)

Determina se o objeto especificado é igual ao objeto atual.

(Herdado de Object)
GetAssembly(Type)

Obtém o assembly carregado no momento no qual o tipo especificado é definido.

GetCallingAssembly()

Retorna o Assembly do método que invocou o método em execução no momento.

GetCustomAttributes(Boolean)

Obtém todos os atributos personalizados para este assembly.

GetCustomAttributes(Type, Boolean)

Obtém os atributos personalizados para esse assembly conforme especificado por tipo.

GetCustomAttributesData()

Retorna informações sobre os atributos que foram aplicados ao Assemblyatual, expressos como objetos CustomAttributeData.

GetEntryAssembly()

Obtém o assembly de entrada do aplicativo em execução.

GetExecutingAssembly()

Obtém o assembly que contém o código que está sendo executado no momento.

GetExportedTypes()

Obtém os tipos públicos definidos neste assembly que são visíveis fora do assembly.

GetFile(String)

Obtém um FileStream para o arquivo especificado na tabela de arquivos do manifesto deste assembly.

GetFiles()

Obtém os arquivos na tabela de arquivos de um manifesto do assembly.

GetFiles(Boolean)

Obtém os arquivos na tabela de arquivos de um manifesto do assembly, especificando se os módulos de recurso devem ser incluídos.

GetForwardedTypes()

Representa um assembly, que é um bloco de construção reutilizável, com controle de versão e autodescrevendo um aplicativo de common language runtime.

GetHashCode()

Retorna o código hash dessa instância.

GetHashCode()

Serve como a função de hash padrão.

(Herdado de Object)
GetLoadedModules()

Obtém todos os módulos carregados que fazem parte deste assembly.

GetLoadedModules(Boolean)

Obtém todos os módulos carregados que fazem parte deste assembly, especificando se os módulos de recurso devem ser incluídos.

GetManifestResourceInfo(String)

Retorna informações sobre como o recurso determinado foi persistido.

GetManifestResourceNames()

Retorna os nomes de todos os recursos neste assembly.

GetManifestResourceStream(String)

Carrega o recurso de manifesto especificado deste assembly.

GetManifestResourceStream(Type, String)

Carrega o recurso de manifesto especificado, com escopo pelo namespace do tipo especificado, desse assembly.

GetModule(String)

Obtém o módulo especificado neste assembly.

GetModules()

Obtém todos os módulos que fazem parte deste assembly.

GetModules(Boolean)

Obtém todos os módulos que fazem parte deste assembly, especificando se os módulos de recurso devem ser incluídos.

GetName()

Obtém um AssemblyName para este assembly.

GetName(Boolean)

Obtém um AssemblyName para esse assembly, definindo a base de código conforme especificado por copiedName.

GetObjectData(SerializationInfo, StreamingContext)
Obsoleto.

Obtém informações de serialização com todos os dados necessários para reinstalar esse assembly.

GetReferencedAssemblies()

Obtém os objetos AssemblyName para todos os assemblies referenciados por este assembly.

GetSatelliteAssembly(CultureInfo)

Obtém o assembly satélite para a cultura especificada.

GetSatelliteAssembly(CultureInfo, Version)

Obtém a versão especificada do assembly satélite para a cultura especificada.

GetType()

Representa um assembly, que é um bloco de construção reutilizável, com controle de versão e autodescrevendo um aplicativo de common language runtime.

GetType()

Obtém o Type da instância atual.

(Herdado de Object)
GetType(String)

Obtém o objeto Type com o nome especificado na instância do assembly.

GetType(String, Boolean)

Obtém o objeto Type com o nome especificado na instância do assembly e, opcionalmente, gera uma exceção se o tipo não for encontrado.

GetType(String, Boolean, Boolean)

Obtém o objeto Type com o nome especificado na instância do assembly, com as opções de ignorar o caso e de gerar uma exceção se o tipo não for encontrado.

GetTypes()

Obtém todos os tipos definidos neste assembly.

IsDefined(Type, Boolean)

Indica se um atributo especificado foi ou não aplicado ao assembly.

Load(AssemblyName)

Carrega um assembly dado seu AssemblyName.

Load(AssemblyName, Evidence)
Obsoleto.

Carrega um assembly dado seu AssemblyName. O assembly é carregado usando as evidências fornecidas.

Load(Byte[])

Carrega o assembly com uma imagem baseada em COFF (formato de arquivo de objeto comum) que contém um assembly emitido.

Load(Byte[], Byte[])

Carrega o assembly com uma imagem baseada em COFF (formato de arquivo de objeto comum) que contém um assembly emitido, opcionalmente incluindo símbolos para o assembly.

Load(Byte[], Byte[], Evidence)
Obsoleto.

Carrega o assembly com uma imagem baseada em COFF (formato de arquivo de objeto comum) que contém um assembly emitido, incluindo opcionalmente símbolos e evidências para o assembly.

Load(Byte[], Byte[], SecurityContextSource)

Carrega o assembly com uma imagem baseada em COFF (formato de arquivo de objeto comum) que contém um assembly emitido, opcionalmente incluindo símbolos e especificando a origem para o contexto de segurança.

Load(String)

Carrega um assembly com o nome especificado.

Load(String, Evidence)
Obsoleto.

Carrega um assembly dado seu nome de exibição e usando as evidências fornecidas.

LoadFile(String)

Carrega o conteúdo de um arquivo de assembly no caminho especificado.

LoadFile(String, Evidence)
Obsoleto.

Carrega um assembly dado seu caminho, carregando o assembly usando as evidências fornecidas.

LoadFrom(String)

Carrega um assembly dado seu nome de arquivo ou caminho.

LoadFrom(String, Byte[], AssemblyHashAlgorithm)
Obsoleto.

Carrega um assembly dado seu nome de arquivo ou caminho, valor de hash e algoritmo de hash.

LoadFrom(String, Evidence)
Obsoleto.

Carrega um assembly dado seu nome de arquivo ou caminho e fornecendo evidências de segurança.

LoadFrom(String, Evidence, Byte[], AssemblyHashAlgorithm)
Obsoleto.

Carrega um assembly dado seu nome de arquivo ou caminho, evidência de segurança, valor de hash e algoritmo de hash.

LoadModule(String, Byte[])

Carrega o módulo, interno para este assembly, com uma imagem baseada em COFF (formato de arquivo de objeto comum) contendo um módulo emitido ou um arquivo de recurso.

LoadModule(String, Byte[], Byte[])

Carrega o módulo, interno para este assembly, com uma imagem baseada em COFF (formato de arquivo de objeto comum) contendo um módulo emitido ou um arquivo de recurso. Os bytes brutos que representam os símbolos do módulo também são carregados.

LoadWithPartialName(String)
Obsoleto.
Obsoleto.
Obsoleto.

Carrega um assembly do diretório do aplicativo ou do cache de assembly global usando um nome parcial.

LoadWithPartialName(String, Evidence)
Obsoleto.

Carrega um assembly do diretório do aplicativo ou do cache de assembly global usando um nome parcial. O assembly é carregado usando as evidências fornecidas.

MemberwiseClone()

Cria uma cópia superficial do Objectatual.

(Herdado de Object)
ReflectionOnlyLoad(Byte[])
Obsoleto.

Carrega o assembly de uma imagem baseada em COFF (formato de arquivo de objeto comum) que contém um assembly emitido. O assembly é carregado no contexto somente reflexão do domínio do aplicativo do chamador.

ReflectionOnlyLoad(String)
Obsoleto.

Carrega um assembly no contexto somente reflexão, considerando seu nome de exibição.

ReflectionOnlyLoadFrom(String)
Obsoleto.

Carrega um assembly no contexto somente reflexão, considerando seu caminho.

SetEntryAssembly(Assembly)

Define o assembly de entrada do aplicativo como o objeto de assembly fornecido.

ToString()

Retorna o nome completo do assembly, também conhecido como o nome de exibição.

UnsafeLoadFrom(String)

Carrega um assembly no contexto de carregamento, ignorando algumas verificações de segurança.

Operadores

Equality(Assembly, Assembly)

Indica se dois objetos Assembly são iguais.

Inequality(Assembly, Assembly)

Indica se dois objetos Assembly não são iguais.

Eventos

ModuleResolve

Ocorre quando o carregador de classe common language runtime não pode resolver uma referência a um módulo interno de um assembly por meio de meios normais.

Implantações explícitas de interface

_Assembly.GetType()

Retorna o tipo da instância atual.

ICustomAttributeProvider.GetCustomAttributes(Boolean)

Retorna uma matriz de todos os atributos personalizados definidos neste membro, excluindo atributos nomeados ou uma matriz vazia se não houver atributos personalizados.

ICustomAttributeProvider.GetCustomAttributes(Type, Boolean)

Retorna uma matriz de atributos personalizados definidos neste membro, identificados por tipo ou uma matriz vazia se não houver atributos personalizados desse tipo.

ICustomAttributeProvider.IsDefined(Type, Boolean)

Indica se uma ou mais instâncias de attributeType está definida nesse membro.

Métodos de Extensão

GetExportedTypes(Assembly)

Representa um assembly, que é um bloco de construção reutilizável, com controle de versão e autodescrevendo um aplicativo de common language runtime.

GetModules(Assembly)

Representa um assembly, que é um bloco de construção reutilizável, com controle de versão e autodescrevendo um aplicativo de common language runtime.

GetTypes(Assembly)

Representa um assembly, que é um bloco de construção reutilizável, com controle de versão e autodescrevendo um aplicativo de common language runtime.

GetCustomAttribute(Assembly, Type)

Recupera um atributo personalizado de um tipo especificado que é aplicado a um assembly especificado.

GetCustomAttribute<T>(Assembly)

Recupera um atributo personalizado de um tipo especificado que é aplicado a um assembly especificado.

GetCustomAttributes(Assembly)

Recupera uma coleção de atributos personalizados que são aplicados a um assembly especificado.

GetCustomAttributes(Assembly, Type)

Recupera uma coleção de atributos personalizados de um tipo especificado que são aplicados a um assembly especificado.

GetCustomAttributes<T>(Assembly)

Recupera uma coleção de atributos personalizados de um tipo especificado que são aplicados a um assembly especificado.

IsDefined(Assembly, Type)

Indica se atributos personalizados de um tipo especificado são aplicados a um assembly especificado.

TryGetRawMetadata(Assembly, Byte*, Int32)

Recupera a seção de metadados do assembly, para uso com MetadataReader.

Aplica-se a

Produto Versões
.NET Core 1.0, Core 1.1, Core 2.0, Core 2.1, Core 2.2, Core 3.0, Core 3.1, 5, 6, 7, 8, 9
.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, 4.8.1
.NET Standard 1.0, 1.1, 1.2, 1.3, 1.4, 1.5, 1.6, 2.0, 2.1
UWP 10.0

Acesso thread-safe

Esse tipo é thread safe.

Confira também