Activator.CreateComInstanceFrom Método
Definição
Importante
Algumas informações se referem a produtos de pré-lançamento que podem ser substancialmente modificados antes do lançamento. A Microsoft não oferece garantias, expressas ou implícitas, das informações aqui fornecidas.
Cria uma instância do objeto COM cujo nome é especificado.
Sobrecargas
CreateComInstanceFrom(String, String) |
Cria uma instância do objeto COM cujo nome é especificado, usando o arquivo de assembly nomeado e o construtor sem parâmetros. |
CreateComInstanceFrom(String, String, Byte[], AssemblyHashAlgorithm) |
Cria uma instância do objeto COM cujo nome é especificado, usando o arquivo de assembly nomeado e o construtor sem parâmetros. |
CreateComInstanceFrom(String, String)
Cria uma instância do objeto COM cujo nome é especificado, usando o arquivo de assembly nomeado e o construtor sem parâmetros.
public:
static System::Runtime::Remoting::ObjectHandle ^ CreateComInstanceFrom(System::String ^ assemblyName, System::String ^ typeName);
public static System.Runtime.Remoting.ObjectHandle CreateComInstanceFrom (string assemblyName, string typeName);
static member CreateComInstanceFrom : string * string -> System.Runtime.Remoting.ObjectHandle
Public Shared Function CreateComInstanceFrom (assemblyName As String, typeName As String) As ObjectHandle
Parâmetros
- assemblyName
- String
O nome de um arquivo que contém um assembly em que o tipo chamado typeName
é procurado.
- typeName
- String
O nome do tipo do qual criar uma instância.
Retornos
Um identificador que deve ser desembrulhado para acessar o objeto recém-criado ou null
para instâncias de Nullable<T>.
Exceções
typeName
ou assemblyName
é null
.
Uma instância não pode ser criada por meio de COM.
-ou-
typeName
não foi encontrado em assemblyName
.
Nenhum construtor correspondente foi encontrado.
assemblyName
não foi encontrado ou o módulo que você está tentando carregar não especifica uma extensão de nome de arquivo.
Não é possível criar uma instância de uma classe abstrata.
-ou-
Esse membro foi invocado com um mecanismo de associação tardia.
O chamador não pode fornecer atributos de ativação para um objeto que não herda de MarshalByRefObject.
assemblyName
é a cadeia de caracteres vazia ("").
Comentários
Use o método ObjectHandle.Unwrap para desembrulhar o valor retornado.
Um atributo System.Runtime.InteropServices.ComVisibleAttribute com um valor de true
deve ser aplicado explicitamente ou por padrão ao tipo COM para que o método CreateComInstanceFrom possa criar uma instância desse tipo; caso contrário, TypeLoadException é gerada.
Para obter informações sobre outras exceções que podem ser geradas por métodos invocados, consulte a seção Exceções dos métodos Assembly.LoadFrom e CreateInstance.
Nota
A partir do .NET Framework 2.0, esse método poderá ser usado para criar tipos não públicos se o chamador tiver recebido ReflectionPermission com o sinalizador ReflectionPermissionFlag.RestrictedMemberAccess e se o conjunto de concessões do assembly que contém os tipos não públicos estiver restrito ao conjunto de concessões do chamador ou a um subconjunto dele. (Consulte considerações de segurança para reflexão.) Para usar essa funcionalidade, seu aplicativo deve ter como destino o .NET Framework 3.5 ou posterior.
Aplica-se a
CreateComInstanceFrom(String, String, Byte[], AssemblyHashAlgorithm)
Cria uma instância do objeto COM cujo nome é especificado, usando o arquivo de assembly nomeado e o construtor sem parâmetros.
public:
static System::Runtime::Remoting::ObjectHandle ^ CreateComInstanceFrom(System::String ^ assemblyName, System::String ^ typeName, cli::array <System::Byte> ^ hashValue, System::Configuration::Assemblies::AssemblyHashAlgorithm hashAlgorithm);
public static System.Runtime.Remoting.ObjectHandle CreateComInstanceFrom (string assemblyName, string typeName, byte[] hashValue, System.Configuration.Assemblies.AssemblyHashAlgorithm hashAlgorithm);
static member CreateComInstanceFrom : string * string * byte[] * System.Configuration.Assemblies.AssemblyHashAlgorithm -> System.Runtime.Remoting.ObjectHandle
Public Shared Function CreateComInstanceFrom (assemblyName As String, typeName As String, hashValue As Byte(), hashAlgorithm As AssemblyHashAlgorithm) As ObjectHandle
Parâmetros
- assemblyName
- String
O nome de um arquivo que contém um assembly em que o tipo chamado typeName
é procurado.
- typeName
- String
O nome do tipo do qual criar uma instância.
- hashValue
- Byte[]
O valor do código hash computado.
- hashAlgorithm
- AssemblyHashAlgorithm
O algoritmo de hash usado para criar arquivos de hash e gerar o nome forte.
Retornos
Um identificador que deve ser desembrulhado para acessar o objeto recém-criado ou null
para instâncias de Nullable<T>.
Exceções
typeName
ou assemblyName
é null
.
assemblyName
é a cadeia de caracteres vazia ("").
Um assembly ou módulo foi carregado duas vezes com duas evidências diferentes.
-ou-
assemblyName
é maior que o comprimento máximo definido pelo sistema.
assemblyName
não foi encontrado ou o módulo que você está tentando carregar não especifica uma extensão de nome de arquivo.
assemblyName
foi encontrado, mas não pode ser carregado.
assemblyName
não é um assembly válido.
Uma base de código que não começa com "file://" foi especificada sem o WebPermission
necessário.
Uma instância não pode ser criada por meio de COM.
-ou-
typeName
não foi encontrado em assemblyName
.
Nenhum construtor correspondente foi encontrado.
Não é possível criar uma instância de uma classe abstrata.
-ou-
Esse membro foi invocado com um mecanismo de associação tardia.
O chamador não pode fornecer atributos de ativação para um objeto que não herda de MarshalByRefObject.
Comentários
Use o método ObjectHandle.Unwrap para desembrulhar o valor retornado.
Um atributo System.Runtime.InteropServices.ComVisibleAttribute com um valor de true
deve ser aplicado explicitamente ou por padrão ao tipo COM para que o método CreateComInstanceFrom possa criar uma instância desse tipo; caso contrário, TypeLoadException é gerada.
Para obter informações sobre outras exceções que podem ser geradas por métodos invocados, consulte a seção Exceções dos métodos Assembly.LoadFrom e CreateInstance.
Nota
A partir do .NET Framework 2.0, esse método poderá ser usado para criar tipos não públicos se o chamador tiver recebido ReflectionPermission com o sinalizador ReflectionPermissionFlag.RestrictedMemberAccess e se o conjunto de concessões do assembly que contém os tipos não públicos estiver restrito ao conjunto de concessões do chamador ou a um subconjunto dele. (Consulte considerações de segurança para reflexão.) Para usar essa funcionalidade, seu aplicativo deve ter como destino o .NET Framework 3.5 ou posterior.