169 похожих чатов

Друзья, подскажите плз чем кардинально отличается GenServer от Agent?

5 ответов

6 просмотров

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, если ошибаюсь - пусть коллеги меня поправят).

Похожие вопросы

Обсуждают сегодня

Вопрос по диагностике ошибок (я знаю в чем, в данном конкретном примере, я знаю, как исправить, пример модельный, понятно, что в реальности бывает намного запутаннее). module...
ⰄⰎⰋⰐⰐⰑⰛⰤⰧⰧⰩⰄ ⰊⰑⰁⰓⰡⰛⰦⰕⰫ
10
А чем вам питонисты не угодили?😂
.
79
Есть какой-нибудь для Delphi/FPC T*Compression(Decompression)Stream на базе LZ4/Zstd/любой другой быстрый(и хорошо сжимающий) алгоритм А ещё лучше в pure pascal А ещё лучше од...
notme
52
А дальше что?.. Записать в файл, потом в Код?.. И потом разбирать как-то?..
Хаскель Моисеевич Гопник
14
доброго времени. db, dw и прочие исполняются при трансляции или при выполнении программы?
lutayyy
10
type TObj = object procedure Init; virtual; end; TObj1 = object(TObj) procedure Init; override; end; procedure TObj1.Init; begin inherited; end; procedur...
Alexander 👋
29
например asm AT&T ... label: .string "hi" ... # not error lea label(%rip), %rax # error ( not compile ) mov %rip, %rax # not error mov (%rip), %rax из форумов прочитал чт...
Simple Sorcerer
6
Почему никто не подсказал, что можно объявить свои типы данных, в которых меньше полей, чем в отданном джейсоне, и добавлять их по необходимости?
Strange Rabbit
10
Всем привет, написал код ниже, но он выдает сегфолт, в чем причина? #include <stdio.h> #include <stdlib.h> #include <string.h> struct product { char *name; float price; };...
buzz базз
86
Есть предложения, как подобное можно упростить?
Hemul GM
12
Карта сайта