共用方式為


List<T>.ICollection.SyncRoot 屬性

定義

取得可用以同步存取 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 的物件。 在 List<T> 的預設實作中,這個屬性一律會傳回目前的執行個體。

實作

備註

System.Collections.Generic 命名空間中集合的預設實作未同步處理。

透過集合進行列舉在本質上並非安全執行緒程序。 若要確保列舉期間的執行緒安全性,您可以在整個列舉期間鎖定集合。 若要讓多重執行緒能夠存取集合以便進行讀取和寫入,您必須實作自己的同步處理。

SyncRoot 傳回 物件,這個物件可用來同步存取 ICollection。 只有在存取集合之前,所有線程都會鎖定此物件時,同步處理才會生效。 下列程式代碼顯示 C#、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) 運算。

適用於

另請參閱