Agent это процесс, который хранит какие-то данные и выполняет на ними функции
GenServer это процесс, который хранит данные и умеет принимать сообщения и обрабатывать синхронные вызовы
Колбэков там меньше чем у GenServer, практически всегда имеет смысл писать GenServer.
Агент это реализация генсервера для хранения данных. Их нельзя сравнивать. Загляните лучше в исходник там 50 строк
https://medium.com/scientific-breakthrough-of-the-afternoon/elixir-agent-vs-genserver-ef443aa4a441 Агент построен на основе GenServer, даёт готовые блокирующие методы get, get_and_update и т.д. Код Agent https://github.com/elixir-lang/elixir/blob/master/lib/elixir/lib/agent.ex Agent при работе запускает Agent.Server, который построен на GenServer https://github.com/elixir-lang/elixir/blob/master/lib/elixir/lib/agent/server.ex Сам GenServer вот если интересно https://github.com/elixir-lang/elixir/blob/master/lib/elixir/lib/gen_server.ex Как это работает. Допустим ты вызываешь Agent.get. Он посылает сообщение Agent.Server-у, хранящему состояние https://github.com/elixir-lang/elixir/blob/master/lib/elixir/lib/agent.ex#L335 . call - это блокирующий вызов, обрабатывается здесь https://github.com/elixir-lang/elixir/blob/master/lib/elixir/lib/agent/server.ex#L11-L13 блокирующий означает что - выполнение кода в Agent.get будет остановлено в ожидании, пока в ответ на отправку call прилетит тупл {:reply, _}, т.е. как будто бы произошёл синхронный вызов функции - процесс, хранящий состояния (в данном случае это один из запущенных Agent.Server) не будет считывать другие сообщения из мессаджбокса, пока не выполнит текущий handle_call. (Если я правильно понимаю - не будет обрабатывать вызовы handle_call, handle_cast, handle_info, если ошибаюсь - пусть коллеги меня поправят).
Обсуждают сегодня