ReadOnlyCollection<T>.ICollection.SyncRoot 屬性
定義
重要
部分資訊涉及發行前產品,在發行之前可能會有大幅修改。 Microsoft 對此處提供的資訊,不做任何明確或隱含的瑕疵擔保。
取得可用以同步存取 ICollection 的物件。
property System::Object ^ System::Collections::ICollection::SyncRoot { System::Object ^ get(); };
object System.Collections.ICollection.SyncRoot { get; }
member this.System.Collections.ICollection.SyncRoot : obj
ReadOnly Property SyncRoot As Object Implements ICollection.SyncRoot
屬性值
可用來同步存取 ICollection 的物件。 在 ReadOnlyCollection<T> 的預設實作中,這個屬性一律會傳回目前的執行個體。
實作
備註
中的 System.Collections.Generic 集合預設實作不會同步處理。
透過集合進行列舉在本質上並非安全執行緒程序。 若要確保列舉期間的執行緒安全性,您可以在整個列舉期間鎖定集合。 若要讓多重執行緒能夠存取集合以便進行讀取和寫入,您必須實作自己的同步處理。
SyncRoot 傳回 物件,這個物件可用來同步存取 ICollection。 只有在存取集合之前,所有線程都會鎖定此物件時,同步處理才會生效。 下列程式代碼顯示 C#、Visual C++ 和 Visual Basic 的 屬性用法 SyncRoot 。
ICollection ic = ...;
lock (ic.SyncRoot) {
// Access the collection.
}
Dim ic As ICollection = ...
SyncLock ic.SyncRoot
' Access the collection.
End SyncLock
ICollection^ ic = ...;
try {
Monitor::Enter(ic->SyncRoot);
// Access the collection.
}
finally {
Monitor::Exit(ic->SyncRoot);
}
擷取這個屬性的值是一種 O(1) 運算。
這個成員是明確介面成員實作, 只有在 ReadOnlyCollection<T> 執行個體轉換成 IDisposable 介面時,才能使用這個成員。