Marshal.GetTypedObjectForIUnknown メソッド
アセンブリ: mscorlib (mscorlib.dll 内)

Dim pUnk As IntPtr Dim t As Type Dim returnValue As Object returnValue = Marshal.GetTypedObjectForIUnknown(pUnk, t)
戻り値
要求されたアンマネージ COM オブジェクトを表す、Type オブジェクトに対応するクラスのインスタンス。


t パラメータは、COM インポート型または COM インポート型のサブタイプである必要があります。さらに、t は、タイプ ライブラリ インポータ ( Tlbimp.exe ) によってメタデータがインポートされた型である必要があります。この型は、クラスである必要があります。COM のクラスの名前を保持している、関連付けられているコクラス インターフェイスであってはいけません。たとえば、Tlbimp.exe は、Myclass を MyclassClass クラスと Myclass コクラス インターフェイスとしてインポートしたとします。このメソッドでは必ず、MyClass ではなく、MyclassClass を使用してください。インポートされたクラスおよびコクラスのインターフェイスの詳細については、「インポート時の型の変換」を参照してください。
pUnk パラメータのオブジェクトが既に取得されている場合、t は無視され、既存のオブジェクトが返されます。pUnk は IUnknown インターフェイス ポインタを表します。ただし、すべての COM インターフェイスは直接的または間接的に IUnknown から派生しているので、このメソッドには任意の COM インターフェイスを渡すことができます。GetTypedObjectForIUnknown が返すオブジェクトはランタイム呼び出し可能ラッパーです。共通言語ランタイムはこれを他のマネージ オブジェクトと同様に管理します。詳細については、ランタイム呼び出し可能ラッパー のトピックを参照してください。
![]() |
---|
このメソッドは SecurityAction.LinkDemand を使用して、信頼関係のないコードからの呼び出しを防ぎます。SecurityPermissionAttribute.UnmanagedCode アクセス許可は、直前の呼び出し元にのみ要求されます。信頼性が一部しか確認されていないコードから呼び出すことができるコードの場合、ユーザー入力を検証せずに Marshal クラスに渡すことは避けてください。LinkDemand メンバの使用に関する重要な制約事項については、「Demand と LinkDemand」を参照してください。 |

- SecurityPermission (アンマネージ コードを呼び出すために必要なアクセス許可)。 UnmanagedCode (関連する列挙体)。LinkDemand (セキュリティ アクション)。

Windows 98, Windows 2000 SP4, Windows CE, Windows Millennium Edition, Windows Mobile for Pocket PC, Windows Mobile for Smartphone, Windows Server 2003, Windows XP Media Center Edition, Windows XP Professional x64 Edition, Windows XP SP2, Windows XP Starter Edition
開発プラットフォームの中には、.NET Framework によってサポートされていないバージョンがあります。サポートされているバージョンについては、「システム要件」を参照してください。


Weblioに収録されているすべての辞書からMarshal.GetTypedObjectForIUnknown メソッドを検索する場合は、下記のリンクをクリックしてください。

- Marshal.GetTypedObjectForIUnknown メソッドのページへのリンク