Solving concurrent problems using Clojure
In this recipe, we will learn Clojure's atoms, refs, and agents. Then we will have a look at Clojure's parallel features.
Getting ready
In this recipe, we will not use an external library. So, the only necessary thing is to start REPL to run code.
How to do it...
Clojure provides solutions for the concurrency problem. Clojure's vars defined in def
are ensured only in single thread and are not safe in concurrent environments. Clojure provides three types of resources for concurrent problem. Here, we will introduce you atoms, refs, and agents that work in concurrent environments.
Using atoms
Atoms provide a way to manage shared, synchronous, and independent states.
Creating and referring atom
The atom
function sets ...
Get Clojure Programming Cookbook now with the O’Reilly learning platform.
O’Reilly members experience books, live events, courses curated by job role, and more from O’Reilly and nearly 200 top publishers.