Прочитать на английском

Поделиться через


ArrayList.Synchronized Метод

Определение

Возвращает синхронизированную (потокобезопасную) оболочку списка.

Перегрузки

Synchronized(ArrayList)

Возвращает синхронизированную (потокобезопасную) оболочку ArrayList.

Synchronized(IList)

Возвращает синхронизированную (потокобезопасную) оболочку IList.

Synchronized(ArrayList)

Исходный код:
ArrayList.cs
Исходный код:
ArrayList.cs
Исходный код:
ArrayList.cs

Возвращает синхронизированную (потокобезопасную) оболочку ArrayList.

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

Параметры

list
ArrayList

Коллекция ArrayList, которую требуется синхронизировать.

Возвращаемое значение

Синхронизированная (потокобезопасная) оболочка ArrayList.

Исключения

list имеет значение null.

Примеры

В следующем примере кода показано, как заблокировать коллекцию с помощью SyncRoot во время всего перечисления.

ArrayList myCollection = new ArrayList();

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

Этот метод является операцией O(1) .

В следующем примере кода показано, как синхронизировать ArrayList, определить, синхронизирована ли ArrayList объект , и использовать синхронизированный ArrayList.

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объекта , все операции должны выполняться с помощью этой оболочки.

Перечисление коллекции не является потокобезопасной процедурой. Даже если коллекция синхронизирована, другие потоки могут ее изменить, что приведет к тому, что перечислитель создаст исключение. Для обеспечения потокобезопасности при перечислении можно либо заблокировать коллекцию на все время перечисления, либо перехватывать исключения, возникающие в результате изменений, внесенных другими потоками.

См. также раздел

Применяется к

Synchronized(IList)

Исходный код:
ArrayList.cs
Исходный код:
ArrayList.cs
Исходный код:
ArrayList.cs

Возвращает синхронизированную (потокобезопасную) оболочку IList.

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

Параметры

list
IList

Коллекция IList, которую требуется синхронизировать.

Возвращаемое значение

Синхронизированная (потокобезопасная) оболочка IList.

Исключения

list имеет значение null.

Примеры

В следующем примере кода показано, как заблокировать коллекцию с помощью SyncRoot во время всего перечисления.

ArrayList myCollection = new ArrayList();

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

Этот метод является операцией O(1) .

Комментарии

Чтобы гарантировать потокобезопасность ArrayListобъекта , все операции должны выполняться с помощью этой оболочки.

Перечисление коллекции не является потокобезопасной процедурой. Даже если коллекция синхронизирована, другие потоки могут ее изменить, что приведет к тому, что перечислитель создаст исключение. Для обеспечения потокобезопасности при перечислении можно либо заблокировать коллекцию на все время перечисления, либо перехватывать исключения, возникающие в результате изменений, внесенных другими потоками.

См. также раздел

Применяется к