AppDomain.CreateComInstanceFrom Metodo

Definizione

Crea una nuova istanza di un tipo COM specificato.Creates a new instance of a specified COM type.

Overload

CreateComInstanceFrom(String, String)

Crea una nuova istanza di un tipo COM specificato.Creates a new instance of a specified COM type. I parametri specificano il nome di un file contenente un assembly che, a sua volta, contiene il tipo e il nome del tipo.Parameters specify the name of a file that contains an assembly containing the type and the name of the type.

CreateComInstanceFrom(String, String, Byte[], AssemblyHashAlgorithm)

Crea una nuova istanza di un tipo COM specificato.Creates a new instance of a specified COM type. I parametri specificano il nome di un file contenente un assembly che, a sua volta, contiene il tipo e il nome del tipo.Parameters specify the name of a file that contains an assembly containing the type and the name of the type.

CreateComInstanceFrom(String, String)

Crea una nuova istanza di un tipo COM specificato.Creates a new instance of a specified COM type. I parametri specificano il nome di un file contenente un assembly che, a sua volta, contiene il tipo e il nome del tipo.Parameters specify the name of a file that contains an assembly containing the type and the name of the type.

public:
 System::Runtime::Remoting::ObjectHandle ^ CreateComInstanceFrom(System::String ^ assemblyName, System::String ^ typeName);
public System.Runtime.Remoting.ObjectHandle CreateComInstanceFrom (string assemblyName, string typeName);
member this.CreateComInstanceFrom : string * string -> System.Runtime.Remoting.ObjectHandle
Public Function CreateComInstanceFrom (assemblyName As String, typeName As String) As ObjectHandle

Parametri

assemblyName
String

Nome di un file contenente un assembly che definisce il tipo richiesto.The name of a file containing an assembly that defines the requested type.

typeName
String

Nome del tipo richiesto.The name of the requested type.

Restituisce

Oggetto che rappresenta un wrapper per la nuova istanza specificata da typeName.An object that is a wrapper for the new instance specified by typeName. Per accedere all'oggetto reale è necessario rimuovere il wrapping del valore restituito.The return value needs to be unwrapped to access the real object.

Eccezioni

assemblyName o typeName è null.assemblyName or typeName is null.

Non è possibile caricare il tipo.The type cannot be loaded.

L'operazione viene tentata in un dominio dell'applicazione non caricato.The operation is attempted on an unloaded application domain.

Non è stato trovato alcun costruttore pubblico senza parametri.No public parameterless constructor was found.

assemblyName non trovata.assemblyName is not found.

typeName è una classe astratta.typeName is an abstract class.

-oppure--or- Questo membro è stato richiamato con un meccanismo di associazione tardiva.This member was invoked with a late-binding mechanism.

Il chiamante non può fornire attributi di attivazione per un oggetto che non eredita da MarshalByRefObject.The caller cannot provide activation attributes for an object that does not inherit from MarshalByRefObject.

assemblyName è una stringa vuota ("").assemblyName is an empty string ("").

assemblyName non è un assembly valido.assemblyName is not a valid assembly.

Un assembly o un modulo è stato caricato due volte con due evidenze diverse.An assembly or module was loaded twice with two different evidences.

L'oggetto COM cui viene fatto riferimento è null.The COM object that is being referred to is null.

Esempio

Nell'esempio seguente viene illustratoThe following sample demonstrates

using namespace System;
using namespace System::Reflection;
using namespace System::Runtime::InteropServices;

[ComVisible(true)]
public ref class MyComVisibleType
{
public:
   MyComVisibleType()
   {
      Console::WriteLine( "MyComVisibleType instantiated!" );
   }

};


[ComVisible(false)]
public ref class MyComNonVisibleType
{
public:
   MyComNonVisibleType()
   {
      Console::WriteLine( "MyComNonVisibleType instantiated!" );
   }

};

void CreateComInstance( String^ typeName )
{
   try
   {
      AppDomain^ currentDomain = AppDomain::CurrentDomain;
      String^ assemblyName = currentDomain->FriendlyName;
      currentDomain->CreateComInstanceFrom( assemblyName, typeName );
   }
   catch ( Exception^ e ) 
   {
      Console::WriteLine( e->Message );
   }

}

int main()
{
   CreateComInstance( "MyComNonVisibleType" ); // Fail!
   CreateComInstance( "MyComVisibleType" ); // OK!
}

using System;
using System.Reflection;
using System.Runtime.InteropServices;

[ComVisible(true)]
class MyComVisibleType {
   public MyComVisibleType() {
      Console.WriteLine("MyComVisibleType instantiated!");
   }
}

[ComVisible(false)]
class MyComNonVisibleType {
   public MyComNonVisibleType() {
      Console.WriteLine("MyComNonVisibleType instantiated!");
   }
}

class Test {
   public static void Main() {
      CreateComInstance("MyComNonVisibleType");   // Fail!
      CreateComInstance("MyComVisibleType");      // OK!
   }
   
   static void CreateComInstance(string typeName) {
      try {
         AppDomain currentDomain = AppDomain.CurrentDomain;
         string assemblyName = currentDomain.FriendlyName;
         currentDomain.CreateComInstanceFrom(assemblyName, typeName);
      } catch (Exception e) {
         Console.WriteLine(e.Message);
      }
   }
}
Imports System.Reflection
Imports System.Runtime.InteropServices

<ComVisible(True)> _
Class MyComVisibleType

   Public Sub New()
      Console.WriteLine("MyComVisibleType instantiated!")
   End Sub

End Class

<ComVisible(False)> _
Class MyComNonVisibleType

   Public Sub New()
      Console.WriteLine("MyComNonVisibleType instantiated!")
   End Sub

End Class

Module Test

   Sub Main()
      CreateComInstance("MyComNonVisibleType")   ' Fail!
      CreateComInstance("MyComVisibleType")      ' OK!
   End Sub

   Sub CreateComInstance(typeName As String)
      Try
         Dim currentDomain As AppDomain = AppDomain.CurrentDomain
         Dim assemblyName As String = currentDomain.FriendlyName
         currentDomain.CreateComInstanceFrom(assemblyName, typeName)
      Catch e As Exception
         Console.WriteLine(e.Message)
      End Try
   End Sub

End Module 'Test

Commenti

Utilizzare questo metodo per creare oggetti in modalità remota senza dovere caricare il tipo localmente.Use this method to create objects remotely without having to load the type locally.

Per accedere all'oggetto reale è necessario decrittografare il valore restituito.The return value must to be unwrapped to access the real object.

Per creare un'istanza di quel tipo, è necessario applicare un attributo System.Runtime.InteropServices.ComVisibleAttribute con un valore di true in modo esplicito o per impostazione predefinita al tipo COM. in caso contrario, viene generata TypeLoadException.A System.Runtime.InteropServices.ComVisibleAttribute attribute with a value of true must be applied either explicitly or by default to the COM type for this method to create an instance of that type; otherwise, TypeLoadException is thrown.

Vedi anche

CreateComInstanceFrom(String, String, Byte[], AssemblyHashAlgorithm)

Crea una nuova istanza di un tipo COM specificato.Creates a new instance of a specified COM type. I parametri specificano il nome di un file contenente un assembly che, a sua volta, contiene il tipo e il nome del tipo.Parameters specify the name of a file that contains an assembly containing the type and the name of the type.

public:
 System::Runtime::Remoting::ObjectHandle ^ CreateComInstanceFrom(System::String ^ assemblyFile, System::String ^ typeName, cli::array <System::Byte> ^ hashValue, System::Configuration::Assemblies::AssemblyHashAlgorithm hashAlgorithm);
public System.Runtime.Remoting.ObjectHandle CreateComInstanceFrom (string assemblyFile, string typeName, byte[] hashValue, System.Configuration.Assemblies.AssemblyHashAlgorithm hashAlgorithm);
member this.CreateComInstanceFrom : string * string * byte[] * System.Configuration.Assemblies.AssemblyHashAlgorithm -> System.Runtime.Remoting.ObjectHandle
Public Function CreateComInstanceFrom (assemblyFile As String, typeName As String, hashValue As Byte(), hashAlgorithm As AssemblyHashAlgorithm) As ObjectHandle

Parametri

assemblyFile
String

Nome di un file contenente un assembly che definisce il tipo richiesto.The name of a file containing an assembly that defines the requested type.

typeName
String

Nome del tipo richiesto.The name of the requested type.

hashValue
Byte[]

Rappresenta il valore del codice hash calcolato.Represents the value of the computed hash code.

hashAlgorithm
AssemblyHashAlgorithm

Rappresenta l'algoritmo hash usato dal manifesto dell'assembly.Represents the hash algorithm used by the assembly manifest.

Restituisce

Oggetto che rappresenta un wrapper per la nuova istanza specificata da typeName.An object that is a wrapper for the new instance specified by typeName. Per accedere all'oggetto reale è necessario rimuovere il wrapping del valore restituito.The return value needs to be unwrapped to access the real object.

Eccezioni

assemblyName o typeName è null.assemblyName or typeName is null.

Non è possibile caricare il tipo.The type cannot be loaded.

L'operazione viene tentata in un dominio dell'applicazione non caricato.The operation is attempted on an unloaded application domain.

Non è stato trovato alcun costruttore pubblico senza parametri.No public parameterless constructor was found.

assemblyFile non trovata.assemblyFile is not found.

typeName è una classe astratta.typeName is an abstract class.

-oppure--or- Questo membro è stato richiamato con un meccanismo di associazione tardiva.This member was invoked with a late-binding mechanism.

Il chiamante non può fornire attributi di attivazione per un oggetto che non eredita da MarshalByRefObject.The caller cannot provide activation attributes for an object that does not inherit from MarshalByRefObject.

assemblyFile è la stringa vuota ("").assemblyFile is the empty string ("").

assemblyFile non è un assembly valido.assemblyFile is not a valid assembly.

Un assembly o un modulo è stato caricato due volte con due evidenze diverse.An assembly or module was loaded twice with two different evidences.

L'oggetto COM cui viene fatto riferimento è null.The COM object that is being referred to is null.

Commenti

Utilizzare questo metodo per creare oggetti in modalità remota senza dovere caricare il tipo localmente.Use this method to create objects remotely without having to load the type locally.

Per accedere all'oggetto reale è necessario decrittografare il valore restituito.The return value must to be unwrapped to access the real object.

Per creare un'istanza di quel tipo, è necessario applicare un attributo System.Runtime.InteropServices.ComVisibleAttribute con un valore di true in modo esplicito o per impostazione predefinita al tipo COM. in caso contrario, viene generata TypeLoadException.A System.Runtime.InteropServices.ComVisibleAttribute attribute with a value of true must be applied either explicitly or by default to the COM type for this method to create an instance of that type; otherwise, TypeLoadException is thrown.

Vedi anche

Si applica a