AppDomain.CreateComInstanceFrom メソッド

定義

指定した COM 型の新しいインスタンスを作成します。Creates a new instance of a specified COM type.

オーバーロード

CreateComInstanceFrom(String, String)

指定した COM 型の新しいインスタンスを作成します。Creates a new instance of a specified COM type. 型を含んでいるアセンブリのファイルの名前と、型の名前をパラメーターで指定します。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)

指定した COM 型の新しいインスタンスを作成します。Creates a new instance of a specified COM type. 型を含んでいるアセンブリのファイルの名前と、型の名前をパラメーターで指定します。Parameters specify the name of a file that contains an assembly containing the type and the name of the type.

CreateComInstanceFrom(String, String)

指定した COM 型の新しいインスタンスを作成します。Creates a new instance of a specified COM type. 型を含んでいるアセンブリのファイルの名前と、型の名前をパラメーターで指定します。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

パラメーター

assemblyName
String

要求された型を定義するアセンブリが格納されているファイルの名前。The name of a file containing an assembly that defines the requested type.

typeName
String

要求された型の名前。The name of the requested type.

戻り値

typeName で指定した新しいインスタンスのラッパーであるオブジェクト。An object that is a wrapper for the new instance specified by typeName. 実際のオブジェクトにアクセスするには、戻り値のラップを解除する必要があります。The return value needs to be unwrapped to access the real object.

例外

assemblyName または typeNamenull です。assemblyName or typeName is null.

型を読み込めません。The type cannot be loaded.

アンロードされたアプリケーション ドメインで操作しようとします。The operation is attempted on an unloaded application domain.

パラメーターなしのパブリック コンストラクターが見つかりませんでした。No public parameterless constructor was found.

assemblyName が見つかりません。assemblyName is not found.

typeName は抽象クラスです。typeName is an abstract class.

- または --or- このメンバーは、遅延バインディング メカニズムで呼び出されました。This member was invoked with a late-binding mechanism.

呼び出し元は、MarshalByRefObject を継承しないオブジェクトのアクティベーション属性を提供できません。The caller cannot provide activation attributes for an object that does not inherit from MarshalByRefObject.

assemblyName が空の文字列 ("") です。assemblyName is an empty string ("").

assemblyName は正しいアセンブリではありません。assemblyName is not a valid assembly.

アセンブリまたはモジュールが、2 つの異なる証拠を使用して 2 回読み込まれました。An assembly or module was loaded twice with two different evidences.

参照されている COM オブジェクトが null です。The COM object that is being referred to is null.

次の例では、The 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

注釈

このメソッドは、型をローカルに読み込まずにオブジェクトをリモートで作成するために使用します。Use this method to create objects remotely without having to load the type locally.

実際のオブジェクトにアクセスするには、戻り値のラップを解除する必要があります。The return value must to be unwrapped to access the real object.

値が trueSystem.Runtime.InteropServices.ComVisibleAttribute 属性は、明示的に、または既定でこのメソッドの COM 型に適用して、その型のインスタンスを作成する必要があります。それ以外の場合、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.

セキュリティ

FileIOPermissionAccess
アセンブリマニフェストを含むファイルを読み取る機能。for the ability to read the file containing the assembly manifest. 関連付けられた列挙型: ReadAssociated enumeration: Read

WebPermission
アセンブリがローカルでない場合に、アセンブリの場所にアクセスする権限。for the ability to access the location of the assembly if the assembly is not local.

こちらもご覧ください

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

指定した COM 型の新しいインスタンスを作成します。Creates a new instance of a specified COM type. 型を含んでいるアセンブリのファイルの名前と、型の名前をパラメーターで指定します。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

パラメーター

assemblyFile
String

要求された型を定義するアセンブリが格納されているファイルの名前。The name of a file containing an assembly that defines the requested type.

typeName
String

要求された型の名前。The name of the requested type.

hashValue
Byte[]

計算されたハッシュ コードの値を表します。Represents the value of the computed hash code.

hashAlgorithm
AssemblyHashAlgorithm

アセンブリ マニフェストが使用するハッシュ アルゴリズムを表します。Represents the hash algorithm used by the assembly manifest.

戻り値

typeName で指定した新しいインスタンスのラッパーであるオブジェクト。An object that is a wrapper for the new instance specified by typeName. 実際のオブジェクトにアクセスするには、戻り値のラップを解除する必要があります。The return value needs to be unwrapped to access the real object.

例外

assemblyName または typeNamenull です。assemblyName or typeName is null.

型を読み込めません。The type cannot be loaded.

アンロードされたアプリケーション ドメインで操作しようとします。The operation is attempted on an unloaded application domain.

パラメーターなしのパブリック コンストラクターが見つかりませんでした。No public parameterless constructor was found.

assemblyFile が見つかりません。assemblyFile is not found.

typeName は抽象クラスです。typeName is an abstract class.

- または --or- このメンバーは、遅延バインディング メカニズムで呼び出されました。This member was invoked with a late-binding mechanism.

呼び出し元は、MarshalByRefObject を継承しないオブジェクトのアクティベーション属性を提供できません。The caller cannot provide activation attributes for an object that does not inherit from MarshalByRefObject.

assemblyFile が空の文字列 ("") です。assemblyFile is the empty string ("").

assemblyFile は正しいアセンブリではありません。assemblyFile is not a valid assembly.

アセンブリまたはモジュールが、2 つの異なる証拠を使用して 2 回読み込まれました。An assembly or module was loaded twice with two different evidences.

参照されている COM オブジェクトが null です。The COM object that is being referred to is null.

注釈

このメソッドは、型をローカルに読み込まずにオブジェクトをリモートで作成するために使用します。Use this method to create objects remotely without having to load the type locally.

実際のオブジェクトにアクセスするには、戻り値のラップを解除する必要があります。The return value must to be unwrapped to access the real object.

値が trueSystem.Runtime.InteropServices.ComVisibleAttribute 属性は、明示的に、または既定でこのメソッドの COM 型に適用して、その型のインスタンスを作成する必要があります。それ以外の場合、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.

セキュリティ

FileIOPermissionAccess
アセンブリマニフェストを含むファイルを読み取る機能。for the ability to read the file containing the assembly manifest. 関連付けられた列挙型: ReadAssociated enumeration: Read

WebPermission
アセンブリがローカルでない場合に、アセンブリの場所にアクセスする権限。for the ability to access the location of the assembly if the assembly is not local.

こちらもご覧ください

適用対象