-
Notifications
You must be signed in to change notification settings - Fork 8
/
Copy pathAgents.scala
38 lines (26 loc) · 1.06 KB
/
Agents.scala
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
package features.agents
import akka.actor.ActorSystem
import akka.agent.Agent
import akka.stream.ActorMaterializer
import scala.concurrent.ExecutionContext.Implicits.global
import scala.concurrent.Future
/**
* Agents are instance linked with a resource, and only this agent it´s able to mutate the resource
* The api of the agent allow us to update the resource in a sync and async fashion way
* Also when we decide to update the resource in async way, we can get a promise from the agent
* to determine when the task as been finish
*/
object Agents extends App {
implicit val context = ActorSystem()
implicit val materializer = ActorMaterializer()
val agent = Agent(5)
runAgent()
def runAgent() {
println(s"Read agent value:${agent.get()}")
val update: Future[Int] = agent.alter(10)
update.onComplete(value => println(s"Agent update value:${value.get}"))
agent.send(value => value + 100)
println(s"Async update not guaranteed:${agent.get()}")
agent.future().onComplete(value => println(s"Wait for data updated:${value.get}"))
}
}