В заключении стоит отметить, что акторы являются удобным способом для предоставления потокобезопасности. Однако, как отмечалось ранее, все обращения к методам актора должны выполняться в асинхронной среде, что потенциально может усложнить поддержку и понимание кодовой базы.
Отличный пример асинхронного кода! Спасибо
Комментарий недоступен
В стандартной акторной модели, как правило содержится очередь операций. Так вот в данном случае данная очередь избавляет нас от тех проблем, которые были затронуты в статье, а именно операция на входе ждёт пока завершится текущая операция в акторе.
Так же, ключевое слово await тоже можно рассматривать как отправку сообщений в стандартной акторной модели.
С точки зрения алгоритмов и структур данных, блокировка get() и add() в этом примере несимметрична. Предполагая, что book - стандартная хеш-таблица, вызовы add() блокируют друг друга и get(). А вот get() друг друга не блокируют, потокобезопасно читать можно сколько угодно. Интересно, учитывает ли этот факт реализация Actor, и учитывает ли программист на Swift, если ему достаточно только применить Actor.
Вся проблема в том, что нету гарантий того, что не будет производится одновременно чтение и запись. И в таком случае чтение не может быть безопасным, если по этому же самому ключу в таблице будет происходить запись новых данных.