GCHandle Struct

Definizione

Fornisce un modo per accedere a un oggetto gestito da una memoria non gestita.

C#
public struct GCHandle
C#
public struct GCHandle : IEquatable<System.Runtime.InteropServices.GCHandle>
C#
[System.Runtime.InteropServices.ComVisible(true)]
public struct GCHandle
Ereditarietà
GCHandle
Attributi
Implementazioni

Esempio

Nell'esempio seguente viene illustrata una App classe che crea un handle a un oggetto gestito usando il metodo, che impedisce la raccolta dell'oggetto GCHandle.Alloc gestito. Una chiamata al EnumWindows metodo passa un delegato e un oggetto gestito (entrambi dichiarati come tipi gestiti, ma non visualizzati) e esegue il cast dell'handle in un IntPtroggetto . La funzione non gestita passa nuovamente il tipo al chiamante come parametro della funzione di callback.

C#
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;
    }
}

Commenti

La GCHandle struttura viene usata con l'enumerazione GCHandleType per creare un handle corrispondente a qualsiasi oggetto gestito. Questo handle può essere uno dei quattro tipi: Weak, WeakTrackResurrection, Normalo Pinned. Quando l'handle è stato allocato, è possibile usarlo per impedire che l'oggetto gestito venga raccolto dal Garbage Collector quando un client non gestito contiene l'unico riferimento. Senza un handle di questo tipo, l'oggetto può essere raccolto dal Garbage Collector prima di completare il proprio lavoro per conto del client non gestito.

È anche possibile usare GCHandle per creare un oggetto aggiunto che restituisce un indirizzo di memoria per impedire al Garbage Collector di spostare l'oggetto in memoria.

Quando l'handle esce dall'ambito, è necessario rilasciarlo in modo esplicito chiamando il Free metodo. In caso contrario, potrebbero verificarsi perdite di memoria. Quando si libera un handle aggiunto, l'oggetto associato verrà rimosso e diventerà idoneo per Garbage Collection, se non sono presenti altri riferimenti.

Proprietà

IsAllocated

Ottiene un valore che indica se l'handle è allocato.

Target

Ottiene o imposta l'oggetto rappresentato da questo handle.

Metodi

AddrOfPinnedObject()

Recupera l'indirizzo dei dati dell'oggetto in un handle Pinned.

Alloc(Object)

Esegue l'allocazione di un handle Normal per l'oggetto specificato.

Alloc(Object, GCHandleType)

Alloca un handle del tipo specificato per l'oggetto specificato.

Equals(GCHandle)

Indica se l'istanza corrente è uguale a un'altra istanza dello stesso tipo.

Equals(Object)

Determina se l'oggetto GCHandle specificato equivale all'oggetto GCHandle corrente.

Free()

Rilascia un oggetto GCHandle.

FromIntPtr(IntPtr)

Restituisce un nuovo oggetto GCHandle creato da un handle per un oggetto gestito.

GetHashCode()

Restituisce un identificatore per l'oggetto GCHandle corrente.

ToIntPtr(GCHandle)

Restituisce la rappresentazione interna come valori interi di un oggetto GCHandle.

Operatori

Equality(GCHandle, GCHandle)

Restituisce un valore che indica se due oggetti GCHandle sono equivalenti.

Explicit(GCHandle to IntPtr)

Oggetto GCHandle archiviato utilizzando una rappresentazione interna di valori interi.

Explicit(IntPtr to GCHandle)

Oggetto GCHandle archiviato utilizzando una rappresentazione interna di valori interi.

Inequality(GCHandle, GCHandle)

Restituisce un valore che indica se due oggetti GCHandle non sono equivalenti.

Si applica a

Prodotto Versioni
.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 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

Vedi anche