Marshal.Release(IntPtr) メソッド

定義

指定したインターフェイスの参照カウントをデクリメントします。

C#
[System.Security.SecurityCritical]
public static int Release(IntPtr pUnk);
C#
public static int Release(IntPtr pUnk);
C#
[System.Runtime.Versioning.SupportedOSPlatform("windows")]
public static int Release(IntPtr pUnk);

パラメーター

pUnk
IntPtr

解放するインターフェイス。

戻り値

pUnk パラメーターで指定したインターフェイスの参照カウントの新しい値。

属性

次の例では、 メソッドを IUnknown 使用してマネージド オブジェクトのインターフェイスを取得する方法を GetIUnknownForObject 示します。 次に、 メソッドを呼び出してインターフェイス ポインターを解放します Release

C#
using System;
using System.Runtime.InteropServices;

class Program
{

    static void Run()
    {

        // Create an int object
        int obj = 1;

        Console.WriteLine("Calling Marshal.GetIUnknownForObject...");

        // Get the IUnKnown pointer for the Integer object
        IntPtr pointer = Marshal.GetIUnknownForObject(obj);

        Console.WriteLine("Calling Marshal.Release...");

        // Always call Marshal.Release to decrement the reference count.
        Marshal.Release(pointer);
    }

    static void Main(string[] args)
    {
        Run();
    }
}

注釈

共通言語ランタイムは COM オブジェクトの参照カウントを自動的に管理するため、このメソッドを直接使用する必要が生じありません。 この値は、テスト目的でのみ使用します。 まれに、カスタム マーシャラーのテストなど、オブジェクトの有効期間を手動で操作する必要がある場合があります。 を呼び出すプログラムのみが を呼び出 Marshal.AddRefRelease必要があります。 参照カウントが 0 に達した後に を呼び出 Release すと、未定義の動作が発生します。

、、または Marshal.GetIDispatchForObjectMarshal.GetIUnknownForObject呼び出Marshal.GetComInterfaceForObjectして、IntPtrリリースへの IUnknown インターフェイス ポインターを表す値を取得できます。 これらのメソッドとマネージド オブジェクトの メソッドを Release 使用して、マネージド オブジェクトの COM 呼び出し可能ラッパーによって表される COM インターフェイスを解放することもできます。

適用対象

製品 バージョン
.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, 10
.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.1, 1.2, 1.3, 1.4, 1.5, 1.6, 2.0, 2.1
UWP 10.0

こちらもご覧ください