Вебинары Разобраться в IT Реферальная программа
Программирование Аналитика Дизайн Маркетинг Управление проектами
25 Июн 2023
2 мин
281

Параллельные списки в JDK Java

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

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

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

В стандартной библиотеке Java (JDK) есть специальные коллекции, предназначенные для работы в многопоточной среде, такие как java.util.concurrent.CopyOnWriteArrayList и java.util.Collections.synchronizedList(). Они обеспечивают потокобезопасность за счет использования блокировок или копирования списка при каждой операции записи.

CopyOnWriteArrayList — это потокобезопасный вариант списка, который создает новую копию списка при каждой операции модификации (вставка, удаление, изменение). Это обеспечивает отличную производительность при чтении, но может быть дорогостоящим при частых операциях записи.

List<String> list = new CopyOnWriteArrayList<>();

Collections.synchronizedList() — это функция обертка, которая возвращает потокобезопасный список. Все операции записи в этот список будут блокироваться, обеспечивая таким образом потокобезопасность.

List<String> list = Collections.synchronizedList(new ArrayList<>());

Оба варианта обеспечивают потокобезопасность, но имеют свои недостатки. CopyOnWriteArrayList лучше подходит для списков, где операции чтения гораздо чаще операций записи. Collections.synchronizedList() подходит для случаев, когда операции записи не так часты, и можно позволить себе небольшую задержку из-за блокировок.

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

Проверь как ты усвоил материалы статьи
Пройди тест и узнай насколько ты лучше других читателей

Добавить комментарий