GCHandle.ToIntPtr(GCHandle) Метод

Определение

Возвращает внутреннее целочисленное представление объекта GCHandle.

public static IntPtr ToIntPtr (System.Runtime.InteropServices.GCHandle value);

Параметры

value
GCHandle

Объект GCHandle для извлечения внутреннего целочисленного представления.

Возвращаемое значение

IntPtr

Объект IntPtr, представляющий объект GCHandle.

Примеры

В следующем примере кода показан App класс, который создает дескриптор управляемого объекта с помощью GCHandle.Alloc метода , который предотвращает сбор управляемого объекта. Вызов EnumWindows метода передает делегат и управляемый объект (оба объявлены как управляемые типы, но не показаны) и приводит дескриптор к объекту IntPtr . Неуправляемая функция передает тип обратно вызывающей стороне в качестве параметра функции обратного вызова.

using System;
using System.IO;
using System.Threading;
using System.Windows.Forms;
using System.Runtime.InteropServices;

public delegate bool CallBack(int handle, IntPtr param);

internal static class NativeMethods
{
    // passing managed object as LPARAM
    // BOOL EnumWindows(WNDENUMPROC lpEnumFunc, LPARAM lParam);

    [DllImport("user32.dll")]
    internal static extern bool EnumWindows(CallBack cb, IntPtr param);
}

public class App
{
    public static void Main()
    {
        Run();
    }

    public static void Run()
    {
        TextWriter tw = Console.Out;
        GCHandle gch = GCHandle.Alloc(tw);

        CallBack cewp = new CallBack(CaptureEnumWindowsProc);

        // platform invoke will prevent delegate to be garbage collected
        // before call ends

        NativeMethods.EnumWindows(cewp, GCHandle.ToIntPtr(gch));
        gch.Free();
    }

    private static bool CaptureEnumWindowsProc(int handle, IntPtr param)
    {
        GCHandle gch = GCHandle.FromIntPtr(param);
        TextWriter tw = (TextWriter)gch.Target;
        tw.WriteLine(handle);
        return true;
    }
}

Применяется к

Өнім Нұсқалар
.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
.NET Framework 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