英語で読む

次の方法で共有


ArrayList.Synchronized メソッド

定義

同期されている (スレッド セーフな) リスト ラッパーを返します。

オーバーロード

Synchronized(ArrayList)

同期されている (スレッド セーフな) ArrayList ラッパーを返します。

Synchronized(IList)

同期されている (スレッド セーフな) IList ラッパーを返します。

Synchronized(ArrayList)

ソース:
ArrayList.cs
ソース:
ArrayList.cs
ソース:
ArrayList.cs

同期されている (スレッド セーフな) ArrayList ラッパーを返します。

C#
public static System.Collections.ArrayList Synchronized (System.Collections.ArrayList list);

パラメーター

list
ArrayList

同期する ArrayList

戻り値

同期されている (スレッド セーフな) ArrayList ラッパー。

例外

listnullです。

次のコード例は、 列挙体全体で を使用して SyncRoot コレクションをロックする方法を示しています。

C#
ArrayList myCollection = new ArrayList();

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

このメソッドは操作です O(1)

次のコード例は、 を同期して、 ArrayListが同期されているかどうかを ArrayList 判断し、同期 ArrayListされた を使用する方法を示しています。

C#
using System;
using System.Collections;
public class SamplesArrayList  {

   public static void Main()  {

      // Creates and initializes a new ArrayList.
      ArrayList myAL = new ArrayList();
      myAL.Add( "The" );
      myAL.Add( "quick" );
      myAL.Add( "brown" );
      myAL.Add( "fox" );

      // Creates a synchronized wrapper around the ArrayList.
      ArrayList mySyncdAL = ArrayList.Synchronized( myAL );

      // Displays the sychronization status of both ArrayLists.
      Console.WriteLine( "myAL is {0}.", myAL.IsSynchronized ? "synchronized" : "not synchronized" );
      Console.WriteLine( "mySyncdAL is {0}.", mySyncdAL.IsSynchronized ? "synchronized" : "not synchronized" );
   }
}
/*
This code produces the following output.

myAL is not synchronized.
mySyncdAL is synchronized.
*/

注釈

のスレッド セーフを保証するには、 ArrayListこのラッパーを介してすべての操作を実行する必要があります。

コレクションの列挙処理は、本質的にスレッドセーフな処理ではありません。 コレクションが同期されていても、他のスレッドがコレクションを変更する場合があり、このときは列挙子から例外がスローされます。 列挙処理を確実にスレッド セーフに行うには、列挙中にコレクションをロックするか、他のスレッドによって行われた変更によってスローされる例外をキャッチします。

こちらもご覧ください

適用対象

.NET 9 およびその他のバージョン
製品 バージョン
.NET Core 1.0, Core 1.1, Core 2.0, Core 2.1, Core 2.2, Core 3.0, Core 3.1, 5, 6, 7, 8, 9
.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, 4.8.1
.NET Standard 2.0, 2.1
UWP 10.0

Synchronized(IList)

ソース:
ArrayList.cs
ソース:
ArrayList.cs
ソース:
ArrayList.cs

同期されている (スレッド セーフな) IList ラッパーを返します。

C#
public static System.Collections.IList Synchronized (System.Collections.IList list);

パラメーター

list
IList

同期する IList

戻り値

同期されている (スレッド セーフな) IList ラッパー。

例外

listnullです。

次のコード例は、 列挙体全体で を使用して SyncRoot コレクションをロックする方法を示しています。

C#
ArrayList myCollection = new ArrayList();

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

このメソッドは操作です O(1)

注釈

のスレッド セーフを保証するには、 ArrayListこのラッパーを介してすべての操作を実行する必要があります。

コレクションの列挙処理は、本質的にスレッドセーフな処理ではありません。 コレクションが同期されていても、他のスレッドがコレクションを変更する場合があり、このときは列挙子から例外がスローされます。 列挙処理を確実にスレッド セーフに行うには、列挙中にコレクションをロックするか、他のスレッドによって行われた変更によってスローされる例外をキャッチします。

こちらもご覧ください

適用対象

.NET 9 およびその他のバージョン
製品 バージョン
.NET Core 1.0, Core 1.1, Core 2.0, Core 2.1, Core 2.2, Core 3.0, Core 3.1, 5, 6, 7, 8, 9
.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, 4.8.1
.NET Standard 2.0, 2.1
UWP 10.0