STM in Clojure and Actors
Learn about STM and actors in the Akka framework.
We'll cover the following
STM in Clojure
STM results in a separation of State and Identity. For example, the stock price at a given time is
immutable. We must use a Transaction to modify anything.
We can include the Clojure jars and use them within Java. For example, in the following code, referenceToAmount
can only be modified inside of a Transaction:
import Clojure.lang.*
Ref referenceToAmount;
LockingTransaction.runInTransaction(new Callable() {
referenceToAmount.set(value);
});
We will get an error if we try to modify the Ref
outside of a Transaction. This makes concurrent programming easier because modifying data outside of a synchronize
block is impossible.
Actors
The Scala-based actor framework, Akka, can also be used from Java.
The following code shows a simple example using the Akka framework with one actor:
import akka.actor.*
public class XActor extends UntypedActor {
public void onReceive(Object message) throws Exception {
if (message instanceof String)
System.out.println((String) message);
}
}
public static void main(String... args) {
ActorSystem system = ActorSystem.create("MySystem");
ActorRef actor = system.actorOf(new Props(XActor.class), "actor");
// the message could be anything implementing Serializable
actor.tell("Message String");
}
An actor runs in a dedicated thread, so it can only do one thing at a time. This makes concurrency much easier to implement.
Get hands-on with 1300+ tech skills courses.