Thread.IsBackground Özellik

Tanım

Bir iş parçacığının arka plan iş parçacığı olup olmadığını belirten bir değer alır veya ayarlar.

C#
public bool IsBackground { get; set; }

Özellik Değeri

Boolean

true bu iş parçacığı arka plan iş parçacığı olacaksa veya ise; aksi takdirde, false .

Özel durumlar

İş parçacığı artık yok.

Örnekler

Aşağıdaki örnek, ön plan ve arka plan iş parçacıklarının davranışını karşıtlığındadır. Bir ön plan iş parçacığı ve bir arka plan iş parçacığı oluşturur. Ön plan iş parçacığı, döngüyü tamamlayana ve sonlandırana kadar for işlemi çalışır tutar. Ancak, örneğin çıktısı olarak, ön plan iş parçacığı yürütmeyi tamamlamış olduğundan, arka plan iş parçacığı yürütmeyi tamamlanmadan önce işlem sonlandırılır.

C#
using System;
using System.Threading;

class Example
{
    static void Main()
    {
        BackgroundTest shortTest = new BackgroundTest(10);
        Thread foregroundThread = 
            new Thread(new ThreadStart(shortTest.RunLoop));

        BackgroundTest longTest = new BackgroundTest(50);
        Thread backgroundThread = 
            new Thread(new ThreadStart(longTest.RunLoop));
        backgroundThread.IsBackground = true;

        foregroundThread.Start();
        backgroundThread.Start();
    }
}

class BackgroundTest
{
    int maxIterations;

    public BackgroundTest(int maxIterations)
    {
        this.maxIterations = maxIterations;
    }

    public void RunLoop()
    {
        for (int i = 0; i < maxIterations; i++) {
            Console.WriteLine("{0} count: {1}", 
                Thread.CurrentThread.IsBackground ? 
                   "Background Thread" : "Foreground Thread", i);
            Thread.Sleep(250);
        }
        Console.WriteLine("{0} finished counting.", 
                          Thread.CurrentThread.IsBackground ? 
                          "Background Thread" : "Foreground Thread");
    }
}
// The example displays output like the following:
//    Foreground Thread count: 0
//    Background Thread count: 0
//    Background Thread count: 1
//    Foreground Thread count: 1
//    Foreground Thread count: 2
//    Background Thread count: 2
//    Foreground Thread count: 3
//    Background Thread count: 3
//    Background Thread count: 4
//    Foreground Thread count: 4
//    Foreground Thread count: 5
//    Background Thread count: 5
//    Foreground Thread count: 6
//    Background Thread count: 6
//    Background Thread count: 7
//    Foreground Thread count: 7
//    Background Thread count: 8
//    Foreground Thread count: 8
//    Foreground Thread count: 9
//    Background Thread count: 9
//    Background Thread count: 10
//    Foreground Thread count: 10
//    Background Thread count: 11
//    Foreground Thread finished counting.

Açıklamalar

İş parçacığı bir arka plan iş parçacığı veya ön plan iş parçacığıdır. Arka plan iş parçacıkları ön plan iş parçacıklarıyla aynıdır, ancak arka plan iş parçacıkları bir işlemi sonlandırmayı engellemez. Bir işleme ait tüm ön plan iş parçacıkları sonlandırıldıktan sonra ortak dil çalışma zamanı işlemi sonlandırılır. Kalan arka plan iş parçacıkları durdurulur ve tamamlanmaz.

Varsayılan olarak, aşağıdaki iş parçacıkları ön planda yürütülür (yani, bunların IsBackground özelliği false döndürür):

  • Birincil iş parçacığı (veya ana uygulama iş parçacığı).

  • Sınıf oluşturucusu çağrılarak oluşturulan tüm Thread iş parçacıkları.

Varsayılan olarak, aşağıdaki iş parçacıkları arka planda yürütülür (yani, IsBackground bunların özelliği true döndürür):

  • İş parçacığı havuzu iş parçacıkları, çalışma zamanı tarafından bakımı yapılan çalışan iş parçacıkları havuzu. sınıfını kullanarak iş parçacığı havuzunu yapılandırabilirsiniz ve iş parçacığı havuzu iş parçacıklarında iş ThreadPool zamanlaması.

    Not

    Görev tabanlı zaman uyumsuz işlemler iş parçacığı havuzu iş parçacıklarında otomatik olarak yürütülür.

  • Yönetilemeyen koddan yönetilen yürütme ortamına giren tüm iş parçacıkları.

Ş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 2.0, 2.1

Ayrıca bkz.