Book Image

Clojure for Java Developers

Book Image

Clojure for Java Developers

Overview of this book

We have reached a point where machines are not getting much faster, software projects need to be delivered quickly, and high quality in software is more demanding as ever. We need to explore new ways of writing software that helps achieve those goals. Clojure offers a new possibility of writing high quality, multi-core software faster than ever, without having to leave your current platform. Clojure for Java developers aims at unleashing the true potential of the Clojure language to use it in your projects. The book begins with the installation and setup of the Clojure environment before moving on to explore the language in-depth. Get acquainted with its various features such as functional programming, concurrency, etc. with the help of example projects. Additionally, you will also, learn how the tooling works, and how it interacts with the Java environment. By the end of this book, you will have a firm grip on Clojure and its features, and use them effectively to write more robust programs.
Table of Contents (14 chapters)
Clojure for Java Developers
Credits
About the Author
About the Reviewer
www.PacktPub.com
Preface
Index

core.async


The core.async is yet another way of programming concurrently; it uses the idea of lightweight threads and channels to communicate between them.

Why lightweight threads?

The lightweight threads are used in languages, such as go and Erlang. They excel in being able to run thousands of threads in a single process.

What is the difference between the lightweight threads and traditional threads?

The traditional threads need to reserve memory. This also takes some time. If you want to create a couple of thousand threads, you will be using a noticeable amount of memory for each thread; asking the kernel to do that also takes time.

What is the difference with lightweight threads? To have a couple of hundred lightweight threads, you only need to create a couple of threads. There is no need to reserve memory and lightweight threads are a mere software idea.

This can be achieved with most languages and Clojure is adding first class support (without changing the language this is part of the Lisp...