Thread.SetData(LocalDataStoreSlot, Object) Yöntem

Tanım

O iş parçacığının geçerli etki alanı için, o sırada çalışan iş parçacığında Belirtilen yuvadaki verileri ayarlar. Daha iyi performans için ThreadStaticAttribute bunun yerine özniteliğiyle işaretlenmiş alanları kullanın.

C#
public static void SetData (LocalDataStoreSlot slot, object? data);
C#
public static void SetData (LocalDataStoreSlot slot, object data);

Parametreler

slot
LocalDataStoreSlot

LocalDataStoreSlotDeğerini ayarlamak için.

data
Object

Ayarlanacak değer.

Örnekler

Bu bölüm iki kod örneği içerir. İlk örnek, ThreadStaticAttribute iş parçacığına özgü bilgileri tutmak için özniteliğiyle işaretlenmiş bir alanın nasıl kullanıldığını gösterir. İkinci örnek, aynı şeyi yapmak için bir veri yuvasını nasıl kullanacağınızı gösterir.

İlk örnek

Aşağıdaki örnek, ThreadStaticAttribute iş parçacığına özgü bilgileri tutmak için ile işaretlenen bir alanın nasıl kullanıldığını gösterir. Bu teknik, ikinci örnekte gösterilen tekniğinden daha iyi performans sağlar.

C#
using System;
using System.Threading;

class Test
{
    static void Main()
    {
        for(int i = 0; i < 3; i++)
        {
            Thread newThread = new Thread(ThreadData.ThreadStaticDemo);
            newThread.Start();
        }
    }
}

class ThreadData
{
    [ThreadStatic]
    static int threadSpecificData;

    public static void ThreadStaticDemo()
    {
        // Store the managed thread id for each thread in the static
        // variable.
        threadSpecificData = Thread.CurrentThread.ManagedThreadId;
      
        // Allow other threads time to execute the same code, to show
        // that the static data is unique to each thread.
        Thread.Sleep( 1000 );

        // Display the static data.
        Console.WriteLine( "Data for managed thread {0}: {1}", 
            Thread.CurrentThread.ManagedThreadId, threadSpecificData );
    }
}

/* This code example produces output similar to the following:

Data for managed thread 4: 4
Data for managed thread 5: 5
Data for managed thread 3: 3
 */

İkinci örnek

Aşağıdaki örnek, bir adlandırılmış veri yuvasının iş parçacığına özgü bilgileri depolamak için nasıl kullanılacağını gösterir.

C#
using System;
using System.Threading;

class Test
{
    public static void Main()
    {
        Thread[] newThreads = new Thread[4];
        int i;
        for (i = 0; i < newThreads.Length; i++)
        {
            newThreads[i] =
                new Thread(new ThreadStart(Slot.SlotTest));
            newThreads[i].Start();
        }
        Thread.Sleep(2000);
        for (i = 0; i < newThreads.Length; i++)
        {
            newThreads[i].Join();
            Console.WriteLine("Thread_{0} finished.",
                newThreads[i].ManagedThreadId);
        }
    }
}

class Slot
{
    private static Random randomGenerator = new Random();

    public static void SlotTest()
    {
        // Set random data in each thread's data slot.
        int slotData = randomGenerator.Next(1, 200);
        int threadId = Thread.CurrentThread.ManagedThreadId;

        Thread.SetData(
            Thread.GetNamedDataSlot("Random"),
            slotData);

        // Show what was saved in the thread's data slot.
        Console.WriteLine("Data stored in thread_{0}'s data slot: {1,3}",
            threadId, slotData);

        // Allow other threads time to execute SetData to show
        // that a thread's data slot is unique to itself.
        Thread.Sleep(1000);

        int newSlotData =
            (int)Thread.GetData(Thread.GetNamedDataSlot("Random"));

        if (newSlotData == slotData)
        {
            Console.WriteLine("Data in thread_{0}'s data slot is still: {1,3}",
                threadId, newSlotData);
        }
        else
        {
            Console.WriteLine("Data in thread_{0}'s data slot changed to: {1,3}",
                threadId, newSlotData);
        }
    }
}

Açıklamalar

Önemli

.NET Framework, iş parçacığı yerel depolaması (TLS) kullanmak için iki mekanizma sağlar: iş parçacığı göreli statik alanları (diğer bir deyişle, özniteliğiyle işaretlenen alanlar ThreadStaticAttribute ) ve veri yuvaları. İş parçacığı göreli statik alanları, veri yuvalardan çok daha iyi performans sağlar ve derleme zamanı tür denetimini etkinleştirir. TLS kullanma hakkında daha fazla bilgi için bkz. Thread Local Depolama: Thread-Relative statik alanları ve veri yuvaları.

İş parçacıkları, iş parçacığına özgü verileri depolamak için yerel bir depo bellek mekanizması kullanır. Ortak dil çalışma zamanı, oluşturulduğunda her bir işleme çok yuvalı bir veri deposu dizisi ayırır. İş parçacığı veri deposunda bir veri yuvası ayırabilir, yuvada bir veri değeri depolayıp alabilir ve iş parçacığı yordamı sona erdikten sonra ve Thread nesne çöp toplama tarafından geri kazanılır. Veri yuvaları iş parçacığı başına benzersizdir. Diğer iş parçacığı (alt iş parçacığı bile değil) bu verileri alabilir.

Not

SetData , Shared başka bir iş parçacığına başvuran bir değişken kullanarak çağırsanız bile, şu anda yürütülmekte olan iş parçacığına her zaman uygulanan bir yöntemdir. Karışıklığı önlemek için, yöntemleri çağırırken sınıf adını kullanın Shared : Thread.SetData(testSlot, "test data") .

Şunlara uygulanır

Ürün Sürümler
.NET 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.