İngilizce dilinde oku

Aracılığıyla paylaş


GC.MaxGeneration Özellik

Tanım

Sistemin şu anda desteklediği en fazla nesil sayısını alır.

C#
public static int MaxGeneration { get; }

Özellik Değeri

Int32

Sıfırdan desteklenen nesil sayısı üst sınırına kadar değişen bir değer.

Örnekler

Aşağıdaki örnekte, şu anda kullanımda MaxGeneration olan en büyük nesil sayısını görüntülemek için özelliğinin nasıl kullanılacağı gösterilmektedir.

C#
using System;

namespace GCCollectIntExample
{
    class MyGCCollectClass
    {
        private const long maxGarbage = 1000;

        static void Main()
        {
            MyGCCollectClass myGCCol = new MyGCCollectClass();

            // Determine the maximum number of generations the system
        // garbage collector currently supports.
            Console.WriteLine("The highest generation is {0}", GC.MaxGeneration);

            myGCCol.MakeSomeGarbage();

            // Determine which generation myGCCol object is stored in.
            Console.WriteLine("Generation: {0}", GC.GetGeneration(myGCCol));

            // Determine the best available approximation of the number
        // of bytes currently allocated in managed memory.
            Console.WriteLine("Total Memory: {0}", GC.GetTotalMemory(false));

            // Perform a collection of generation 0 only.
            GC.Collect(0);

            // Determine which generation myGCCol object is stored in.
            Console.WriteLine("Generation: {0}", GC.GetGeneration(myGCCol));

            Console.WriteLine("Total Memory: {0}", GC.GetTotalMemory(false));

            // Perform a collection of all generations up to and including 2.
            GC.Collect(2);

            // Determine which generation myGCCol object is stored in.
            Console.WriteLine("Generation: {0}", GC.GetGeneration(myGCCol));
            Console.WriteLine("Total Memory: {0}", GC.GetTotalMemory(false));
            Console.Read();
        }

        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();
            }
        }
    }
}

Açıklamalar

Bir nesnenin oluşturma sayısı veya yaşı, bir nesnenin kullanım ömrünün uygulama tanımlı göreli ölçüsüdür. En son oluşturulan nesneler nesil 0'dadır ve en eski nesneler özelliği tarafından MaxGeneration döndürülen nesilden küçük veya buna eşit bir nesildedir.

Atık toplayıcı, eski belleğe göre daha yeni belleğin çöp toplamaya uygun olma olasılığının daha yüksek olduğunu varsayar. Bu nedenle, atık toplayıcı, belleği her geri kazanışında nesil numaralarını ayarlayarak performansını artırır ve MaxGeneration özellik değeri zaman içinde büyüyebilir.

Nesne eskime uygulanırsa, MaxGeneration özellik sistem tarafından kullanılan en yüksek nesil sayısını döndürür; aksi takdirde, bu özellik sıfır döndürür.

Bu uygulama için, özelliği tarafından döndürülen değerin MaxGeneration , yürütülen uygulamanın ömrü boyunca sabit kalacağı garanti edilir.

MaxGeneration Oluşturma parametresini alan yöntemi çağırırken Collect(Int32) belirtebileceğiniz en yüksek değeri belirlemek için özelliğini kullanın.

Şunlara uygulanır

Ürün Sürümler
.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
.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
.NET Standard 1.0, 1.1, 1.2, 1.3, 1.4, 1.5, 1.6, 2.0, 2.1
UWP 10.0

Ayrıca bkz.