Aracılığıyla paylaş


ArrayList.SyncRoot Özellik

Tanım

ArrayListerişimini eşitlemek için kullanılabilecek bir nesnesi alır.

public:
 virtual property System::Object ^ SyncRoot { System::Object ^ get(); };
public virtual object SyncRoot { get; }
member this.SyncRoot : obj
Public Overridable ReadOnly Property SyncRoot As Object

Özellik Değeri

erişimi ArrayListeşitlemek için kullanılabilecek bir nesne.

Uygulamalar

Örnekler

Aşağıdaki kod örneği, tüm numaralandırma sırasında kullanarak SyncRoot koleksiyonun nasıl kilitlenmesini gösterir.

ArrayList myCollection = new ArrayList();

lock(myCollection.SyncRoot)
{
    foreach (object item in myCollection)
    {
        // Insert your code here.
    }
}
Dim myCollection As New ArrayList()

SyncLock myCollection.SyncRoot
    For Each item As Object In myCollection
        ' Insert your code here.
    Next item
End SyncLock

Bu özelliğin değerini almak bir O(1) işlemdir.

Açıklamalar

öğesinin ArrayListeşitlenmiş bir sürümünü oluşturmak için yöntemini kullanın Synchronized . Ancak, türetilmiş sınıflar özelliğini kullanarak SyncRoot kendi eşitlenmiş sürümünü ArrayList sağlayabilir. Eşitleme kodu üzerinde doğrudan ArrayListüzerinde değil üzerinde işlem SyncRootArrayListgerçekleştirmelidir. Bu, diğer nesnelerden türetilen koleksiyonların düzgün çalışmasını sağlar. Özellikle, nesneyi aynı anda değiştirebilecek diğer iş parçacıklarıyla düzgün eşitlemeyi ArrayList korur.

Bir koleksiyonda numaralandırma, iş parçacığı açısından güvenli bir yordam değildir. Bir koleksiyon eşitlendiğinde bile, diğer iş parçacıkları yine de koleksiyonu değiştirebilir ve bu da numaralandırıcının bir özel durum oluşturmasına neden olur. Numaralandırma sırasında iş parçacığı güvenliğini garanti etmek için, tüm numaralandırma sırasında koleksiyonu kilitleyebilir veya diğer iş parçacıkları tarafından yapılan değişikliklerden kaynaklanan özel durumları yakalayabilirsiniz.

Şunlara uygulanır

Ayrıca bkz.