共用方式為


Array.SyncRoot 屬性

定義

取得一個物件,可用來同步存取 Array

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

屬性值

一個可以用來同步存取 Array的物件。

實作

範例

以下程式碼範例展示了如何利用 屬性 SyncRoot 在整個列舉過程中鎖定陣列。

Array myArray = new int[] { 1, 2, 4 };
lock(myArray.SyncRoot)
{
    foreach (Object item in myArray)
        Console.WriteLine(item);
}
let myArray = [| 1; 2; 4|]
lock myArray.SyncRoot (fun () ->
    for item in myArray do
        printfn $"{item}" )
Dim myArray As Array = New Integer() { 1, 2, 4 }
SyncLock(myArray.SyncRoot) 
    For Each item As Object In myArray
        Console.WriteLine(item)
    Next
End SyncLock

備註

此特性實作了介面。System.Collections.ICollection

基於 的 Array .NET 類別則利用 屬性 SyncRoot 提供自己的同步版本集合。

使用陣列的類別也可以利用這個 SyncRoot 特性實作自己的同步。 同步程式碼必須對集合的操作 SyncRoot 執行,而非直接對集合執行。 這確保了從其他物件衍生出的集合的正確運作。 具體來說,它會與可能同時修改集合的其他執行緒保持適當的同步。 請注意,某些實 SyncRoot 作可能會回傳 本身 Array

透過集合列舉本質上不是一個執行緒安全的程序。 即使集合已同步,其他執行緒仍可能修改該集合,導致列舉器拋出例外。 為了確保列舉過程中執行緒的安全,你可以在整個列舉過程中鎖定該集合,或是捕捉其他執行緒變更所產生的例外。

取得此性質的值為 O(1) 運算。

適用於

另請參閱