Observing Changes Functionally
Use Observing Changes Functionally to compare familiar Java design-pattern habits with smaller Clojure shapes built from data, functions, namespaces, protocols, and explicit boundaries.
This section turns Observing Changes Functionally into concrete design checkpoints for Java engineers moving toward idiomatic Clojure. Treat the child pages as refactoring lenses: keep the useful design intent, then choose the smallest Clojure mechanism that makes the boundary explicit.
| Checkpoint |
Java instinct to question |
Clojure move to practice |
| Representation |
Introduce a class, interface, or pattern role before the data shape is clear |
Start with immutable data and named transformations |
| Extension |
Add hierarchy, listeners, factories, or wrappers for variation |
Use functions, maps, protocols, multimethods, or namespaces at explicit seams |
| Effects |
Hide I/O, state, or lifecycle behind object identity |
Push effects to narrow edges and keep the core easy to test at the REPL |
Work through these pages in order when refactoring an existing Java design. For new Clojure code, start with the simplest data flow that passes tests; add abstraction only when call sites repeat the same boundary.
In this section
-
The Observer Pattern in OOP
Use The Observer Pattern in OOP to compare familiar Java design-pattern habits with smaller Clojure shapes built from data, functions, namespaces, protocols, and explicit boundaries.
-
Challenges with Observers in OOP
Use Challenges with Observers in OOP to compare familiar Java design-pattern habits with smaller Clojure shapes built from data, functions, namespaces, protocols, and explicit boundaries.
-
Functional Reactive Programming (FRP)
Use Functional Reactive Programming (FRP) to compare familiar Java design-pattern habits with smaller Clojure shapes built from data, functions, namespaces, protocols, and explicit boundaries.
-
Using `core.async` for Event Handling
Use Using `core.async` for Event Handling to compare familiar Java design-pattern habits with smaller Clojure shapes built from data, functions, namespaces, protocols, and explicit boundaries.
-
Implementing Pub/Sub Patterns
Use Implementing Pub/Sub Patterns to compare familiar Java design-pattern habits with smaller Clojure shapes built from data, functions, namespaces, protocols, and explicit boundaries.
-
Real-Time Data Feeds with Clojure: A Case Study
Explore the implementation of real-time data feeds using Clojure and functional programming patterns. Learn how to build a stock ticker with core.async for efficient event handling.
Revised on Saturday, May 23, 2026