class CreateUser(user: User, replyTo: ActorRef[ActionPerformed]) имеет параметр replyTo: ActorRef[ActionPerformed], но использование этого кейс-класса в дальнейшем производится только с помощью вайлкарда: def createUser(user: User): Future[ActionPerformed] =
userRegistry.ask(CreateUser(user, _)), что это значит?
в проекте определён только один актор UserRegistry с Behavior[Command], а не Behavior[ActionPerformed]. Уходят ли ответы на самом деле актору с Behavior[ActionPerformed] или ответы уходят самому же себе?если ответ уходит в актор ActorRef[ActionPerformed], то откуда он берётся?мы же его не создавали
Насколько я понял, это пример на typed-actors. Здесь ActionPerformed это тип сообщения, который возвращается. https://doc.akka.io/docs/akka/2.4/scala/typed.html
возвращается кому?
да, ожидает сообщение типа Command. а ActionPerformed это же другой тип, под сообщения которого не определено поведения я всё правильно понимаю?
Command он паттернматчит в GetUsers, CreateUsers и т.д. Здесь определён тип для сообщения, которое будет ответом на заданное действие (...replyTo : ActorRef[_]) Я сам только начал работать с akka actors, тут видимо в самом действии replyTo содержится адрес. ActorRef определяет тип сообщения, которое можно отослать. А так почитайте доки Akka Typed Actors, там это объясняется лучше.
запись replyTo: ActorRef[ActionPerformed] означает, что replyTo - это актор, принимающий сообщения типа ActionPerformed, разве нет? это и в записи replyTo ! ActionPerformed(s"User \${user.name} created.") отражено Вопрос в том, где такой актор создаётся?не могу найти в этом проекте
тут как раз создаётся актор UserRegistry, который знает как обрабатывать сообщения типа Command, а не ActionPerformed
В чем проблема, если каждый Command уже знает как это делать?
Command ничего не может знать, это просто тип сообщения знать могут акторы. как создаётся актор принимающий сообщения типа Command я вижу, а как создаётся актор принимающий сообщения типа ActionPerformed - не вижу (при этом к нему в коде идёт обращение, как ни странно)
Так вы почитайте документацию... Это не актор принимает сообщения типа ActionPerformed, это определяется в каждой Command для тайпчека сообщений.
я читал :) replyTo ! ActionPerformed(s"User \${user.name} created.") вот эта запись что означает, в таком случае?
Она означает, что будет отправлено сообщение типа ActionPerformed
Это значит, что в классе command передается актор, который имеет behavior для типа actionperformed
да. а на практике передаются вайлдкарды
и такой актор нигде не определяется. так можно?
Можно через ask, об этом и есть пример. Ask в виде фьючи представляет ответ от актора и для этого не требуется создавать отдельный актор
Это не вайлдкарты, это лямбды
ага, вот теперь понятно, что так можно, спасибо
https://doc.akka.io/docs/akka/current/typed/interaction-patterns.html
отлично!благодарю!
Пожалуйста
Обсуждают сегодня