GCHandle Struktur
Definisi
Penting
Beberapa informasi terkait produk prarilis yang dapat diubah secara signifikan sebelum dirilis. Microsoft tidak memberikan jaminan, tersirat maupun tersurat, sehubungan dengan informasi yang diberikan di sini.
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
- 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
, , WeakTrackResurrection
Normal
, 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 Free metode ; jika tidak, kebocoran 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. |