GCHandle Struktur

Definisi

Menyediakan cara untuk mengakses objek terkelola dari memori yang tidak dikelola.

public value class GCHandle
public value class GCHandle : IEquatable<System::Runtime::InteropServices::GCHandle>
public struct GCHandle
public struct GCHandle : IEquatable<System.Runtime.InteropServices.GCHandle>
[System.Runtime.InteropServices.ComVisible(true)]
public struct GCHandle
type GCHandle = struct
[<System.Runtime.InteropServices.ComVisible(true)>]
type GCHandle = struct
Public Structure GCHandle
Public Structure GCHandle
Implements IEquatable(Of GCHandle)
Warisan
GCHandle
Atribut
Penerapan

Contoh

Contoh berikut menunjukkan App kelas yang membuat handel ke objek terkelola menggunakan GCHandle.Alloc metode , yang mencegah objek terkelola dikumpulkan. Panggilan ke EnumWindows metode meneruskan delegasi dan objek terkelola (keduanya dinyatakan sebagai jenis terkelola, tetapi tidak ditampilkan), dan melemparkan handel ke IntPtr. Fungsi yang tidak dikelola meneruskan jenis kembali ke pemanggil sebagai parameter fungsi panggilan balik.

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;
    }
}
Imports System.IO
Imports System.Threading
Imports System.Windows.Forms
Imports System.Runtime.InteropServices
Imports System.Security.Permissions

Public Delegate Function CallBack(ByVal handle As Integer, ByVal param As IntPtr) As Boolean


Friend Module NativeMethods

    ' passing managed object as LPARAM
    ' BOOL EnumWindows(WNDENUMPROC lpEnumFunc, LPARAM lParam);
    <DllImport("user32.dll")>
    Friend Function EnumWindows(ByVal cb As CallBack, ByVal param As IntPtr) As Boolean
    End Function
End Module


Module App

    Sub Main()

        Run()

    End Sub

    <SecurityPermission(SecurityAction.Demand, UnmanagedCode:=True)>
    Sub Run()

        Dim tw As TextWriter = Console.Out
        Dim gch As GCHandle = GCHandle.Alloc(tw)

        Dim cewp As CallBack
        cewp = AddressOf CaptureEnumWindowsProc

        ' platform invoke will prevent delegate to be garbage collected
        ' before call ends
        NativeMethods.EnumWindows(cewp, GCHandle.ToIntPtr(gch))
        gch.Free()

    End Sub


    Function CaptureEnumWindowsProc(ByVal handle As Integer, ByVal param As IntPtr) As Boolean
        Dim gch As GCHandle = GCHandle.FromIntPtr(param)
        Dim tw As TextWriter = CType(gch.Target, TextWriter)
        tw.WriteLine(handle)
        Return True

    End Function
End Module

Keterangan

Struktur GCHandle digunakan dengan GCHandleType enumerasi untuk membuat handel yang sesuai dengan objek terkelola apa pun. Handel ini bisa menjadi salah satu dari empat jenis: Weak, , WeakTrackResurrectionNormal, atau Pinned. Ketika handel telah dialokasikan, Anda dapat menggunakannya untuk mencegah objek terkelola dikumpulkan oleh pengumpul sampah ketika klien yang tidak dikelola memegang satu-satunya referensi. Tanpa pegangan seperti itu, objek dapat dikumpulkan oleh pengumpul sampah sebelum menyelesaikan pekerjaannya atas nama klien yang tidak dikelola.

Anda juga dapat menggunakan GCHandle untuk membuat objek yang disematkan yang mengembalikan alamat memori untuk mencegah pengumpul sampah memindahkan objek dalam memori.

Ketika handel keluar dari cakupan, Anda harus secara eksplisit melepaskannya dengan memanggil metode ; jika tidak, kebocoran Free memori dapat terjadi. Ketika Anda membebaskan handel yang disematkan, objek terkait akan tidak disematkan dan akan memenuhi syarat untuk pengumpulan sampah, jika tidak ada referensi lain untuk itu.

Properti

IsAllocated

Mendapatkan nilai yang menunjukkan apakah handel dialokasikan.

Target

Mendapatkan atau mengatur objek yang diwakili handel ini.

Metode

AddrOfPinnedObject()

Mengambil alamat data objek dalam Pinned handel.

Alloc(Object)

Mengalokasikan Normal handel untuk objek yang ditentukan.

Alloc(Object, GCHandleType)

Mengalokasikan handel dari jenis yang ditentukan untuk objek yang ditentukan.

Equals(GCHandle)

Menunjukkan apakah instans saat ini sama dengan instans lain dengan jenis yang sama.

Equals(Object)

Menentukan apakah objek yang ditentukan GCHandle sama dengan objek saat ini GCHandle .

Free()

Merilis GCHandle.

FromIntPtr(IntPtr)

Mengembalikan objek baru GCHandle yang dibuat dari handel ke objek terkelola.

GetHashCode()

Mengembalikan pengidentifikasi untuk objek saat ini GCHandle .

ToIntPtr(GCHandle)

Mengembalikan representasi bilangan bulat internal objek GCHandle .

Operator

Equality(GCHandle, GCHandle)

Mengembalikan nilai yang menunjukkan apakah dua GCHandle objek sama.

Explicit(GCHandle to IntPtr)

GCHandle disimpan menggunakan representasi bilangan bulat internal.

Explicit(IntPtr to GCHandle)

GCHandle disimpan menggunakan representasi bilangan bulat internal.

Inequality(GCHandle, GCHandle)

Mengembalikan nilai yang menunjukkan apakah dua GCHandle objek tidak sama.

Berlaku untuk

Lihat juga