Questo argomento non è stato ancora valutato - Valuta questo argomento

Metodo GC.Collect

Aggiornamento: novembre 2007

Forza un immediato Garbage Collection di tutte le generazioni.

Spazio dei nomi:  System
Assembly:  mscorlib (in mscorlib.dll)
public static void Collect()
public static void Collect()
public static function Collect()

Utilizzare questo metodo per provare a recuperare tutta la memoria non accessibile.

Tutti gli oggetti, indipendentemente dal periodo di tempo in cui sono rimasti in memoria, vengono sottoposti alla procedura di Garbage Collection, ad eccezione di quelli per cui sono presenti riferimenti nel codice gestito. Utilizzare questo metodo per forzare il sistema a tentare di recuperare la quantità massima di memoria disponibile.

Nell'esempio riportato di seguito viene illustrato come utilizzare il metodo Collect per eseguire un Garbage Collection su tutte le generazioni di memoria. Il codice genera un numero di oggetti inutilizzati, quindi chiama il metodo Collect per eliminarli dalla memoria.

using System;

namespace GCCollectExample
{
    class MyGCCollectClass
    {
        private const int maxGarbage = 1000;

        static void Main()
        {
            // Put some objects in memory.
            MyGCCollectClass.MakeSomeGarbage();
            Console.WriteLine("Memory used before collection: {0}", GC.GetTotalMemory(false));

            // Collect all generations of memory.
            GC.Collect();
            Console.WriteLine("Memory used after full collection: {0}", GC.GetTotalMemory(true));
        }

        static void MakeSomeGarbage()
        {
            Version vt;

            for(int i = 0; i < maxGarbage; i++)
            {
                // Create objects and release them to fill up memory
                // with unused objects.
                vt = new Version();
            }
        }
    }
}


package GCCollectExample ; 

import System.* ;

class MyGCCollectClass
{
    private static final int maxGarbage = 1000;

    public static void main(String[] args)
    {
        // Put some objects in memory.
        MyGCCollectClass.MakeSomeGarbage();
        Console.WriteLine("Memory used before collection: {0}", 
            System.Convert.ToString(GC.GetTotalMemory(false)));

        // Collect all generations of memory.
        GC.Collect();
        Console.WriteLine("Memory used after full collection: {0}", 
            System.Convert.ToString(GC.GetTotalMemory(true)));
    } //main

    static void MakeSomeGarbage()
    {
        Version vt;

        for (int i = 0; i < maxGarbage; i++) {
            // Create objects and release them to fill up memory
            // with unused objects.
            vt = new Version();
        }
    } //MakeSomeGarbage
} //MyGCCollectClass


Windows Vista, Windows XP SP2, Windows XP Media Center Edition, Windows XP Professional x64 Edition , Windows XP Starter Edition, Windows Server 2003, Windows Server 2000 SP4, Windows Millennium Edition, Windows 98, Windows CE, Windows Mobile per Smartphone, Windows Mobile per Pocket PC, Xbox 360

.NET Framework e .NET Compact Framework non supportano tutte le versioni di ciascuna piattaforma. Per un elenco delle versioni supportate, vedere Requisiti di sistema di .NET Framework.

.NET Framework

Supportato in: 3.5, 3.0, 2.0, 1.1, 1.0

.NET Compact Framework

Supportato in: 3.5, 2.0, 1.0

XNA Framework

Supportato in: 2.0, 1.0
Il documento è risultato utile?
(1500 caratteri rimanenti)

Aggiunte alla community

AGGIUNGI
© 2013 Microsoft. Tutti i diritti riservati.