Clojure logo.svg
Designed byRich Hickey
First appeared2007; 11 years ago (2007)
Stable release
1.9[1] / December 8, 2017; 11 months ago (2017-12-08)
Typing disciplinedynamic, strong
PlatformJava, JavaScript, .NET
LicenseEclipse Public License
Filename extensions.clj, .cljs, .cljc, .edn
Influenced by
C#, C++,[2]Common Lisp, Erlang, Haskell, Java, Mathematica,[3]ML, Prolog, Racket,[4]Ruby,[5]Scheme
Elixir, Hy, Pixie, Rhine

Clojure (, like closure)[6] is a modern, dynamic, and functional dialect of the Lisp programming language on the Java platform.[7][8] Like other Lisps, Clojure treats code as data and has a Lisp macro system.[9] The current development process is community-driven,[10] overseen by Rich Hickey as its benevolent dictator for life (BDFL).[11]

Clojure encourages immutability and immutable data structures. While its type system is entirely dynamic, recent efforts have also sought the implementation of gradual typing.[12] Clojure encourages programmers to be explicit about managing state and identity.[13] This focus on programming with immutable values and explicit progression-of-time constructs is intended to facilitate developing more robust programs, especially multithreaded ones.[14][15]

Clojure is used in industry by firms such as Funding Circle,[16]Walmart,[17]Puppet,[18], Apple,[19][20] and other large software firms.[21] Commercial support for Clojure is provided by Cognitect.[22] Annual Clojure conferences are organised every year across the globe, the most famous of them being Clojure/conj (US east coast),[23] Clojure/West (US west coast),[24] and EuroClojure (Europe).[25]

History and development process

Rich Hickey, the creator of Clojure

Rich Hickey is the creator of the Clojure language.[7] Before Clojure, he developed dotLisp, a similar project based on the .NET Framework,[26] and three earlier attempts to provide interoperability between Lisp and Java: a Java foreign language interface for Common Lisp (jfli),[27] A Foreign Object Interface for Lisp (FOIL),[28] and a Lisp-friendly interface to Java Servlets (Lisplets).[29]

Hickey spent about 2½ years working on Clojure before releasing it publicly, much of that time working exclusively on Clojure with no outside funding. At the end of this time, Hickey sent an email announcing the language to some friends in the Common Lisp community.

The development process is community-driven[10] and is managed at the Clojure Community website.[30] The website contains planning documents and an issue tracker where bugs may be filed. General development discussion occurs at the Clojure Dev Google Group.[31] Anyone can submit bug reports and ideas, but to contribute patches, one must sign the Clojure Contributor agreement.[32] JIRA tickets are processed by a team of screeners and finally Rich Hickey approves the changes.[33]

Design philosophy

Rich Hickey developed Clojure because he wanted a modern Lisp for functional programming, symbiotic with the established Java platform, and designed for concurrency.[14][15][34]

Clojure's approach to state is characterized by the concept of identities,[35] which are represented as a series of immutable states over time. Since states are immutable values, any number of workers can operate on them in parallel, and concurrency becomes a question of managing changes from one state to another. For this purpose, Clojure provides several mutable reference types, each having well-defined semantics for the transition between states.[13][35]


Version Release date Major features added
2007-10-16[36] Initial public release
1.0 2009-05-04[37] First stable release[38]
1.1 2009-12-31[37] Futures[39]
1.2 2010-08-19[37] Protocols[40]
1.3 2011-09-23[37] Enhanced primitive support[41]
1.4 2012-04-15[37] Reader literals
1.5 2013-03-01[37] Reducers
1.6 2014-03-25[42] Java API, improved hashing algorithms
1.7 2015-06-30[43] Transducers, reader conditionals
1.8 2016-01-19[44] Additional string functions, direct linking, socket server
Current stable version: 1.9 2017-12-08[45] Integration with spec, command-line tools
Old version
Older version, still supported
Latest version
Latest preview version
Future release

Clojure runs on the Java platform and as a result, integrates with Java and fully supports calling Java code from Clojure,[46] and Clojure code can be called from Java also.[47] The community uses Leiningen[48] for project automation, providing support for Maven integration. Leiningen handles project package management and dependencies and is configured using Clojure syntax.[48]

Like most other Lisps, Clojure's syntax is built on S-expressions that are first parsed into data structures by a reader before being compiled.[49] Clojure's reader supports literal syntax for maps, sets and vectors in addition to lists, and these are compiled to the mentioned structures directly.[49] Clojure is a Lisp-1 and is not intended to be code-compatible with other dialects of Lisp, since it uses its own set of data structures incompatible with other Lisps.[49][50]

As a Lisp dialect, Clojure supports functions as first-class objects, a read-eval-print loop (REPL), and a macro system.[51] Clojure's Lisp macro system is very similar to that in Common Lisp with the exception that Clojure's version of the backquote (termed "syntax quote") qualifies symbols with their namespace. This helps prevent unintended name capture, as binding to namespace-qualified names is forbidden. It is possible to force a capturing macro expansion, but it must be done explicitly. Clojure does not allow user-defined reader macros, but the reader supports a more constrained form of syntactic extension.[52] Clojure supports multimethods[53] and for interface-like abstractions has a protocol[54] based polymorphism and data type system using records,[55] providing high-performance and dynamic polymorphism designed to avoid the expression problem.

Clojure has support for lazy sequences and encourages the principle of immutability and persistent data structures. As a functional language, emphasis is placed on recursion and higher-order functions instead of side-effect-based looping. Automatic tail call optimization is not supported as the JVM does not support it natively;[56][57][58] it is possible to do so explicitly by using the recur keyword.[59] For parallel and concurrent programming Clojure provides software transactional memory,[60] a reactive agent system,[61] and channel-based concurrent programming.[62]

Clojure 1.7 introduced reader conditionals by allowing the embedding of Clojure and ClojureScript code in the same namespace.[43][63] Transducers were added as a method for composing transformations. Transducers enable higher-order functions such as map and fold to generalize over any source of input data. While traditionally these functions operate on sequences, transducers allow them to work on channels and let the user define their own models for transduction.[64][65][66]

Platforms and popularity

The primary platform of Clojure is Java,[8][46] but other target implementations exist. The most notable of these are ClojureScript,[67] which compiles to ECMAScript 3,[68] and ClojureCLR,[69] a full port on the .NET platform, interoperable with its ecosystem. A survey of the Clojure community with 1,060 respondents conducted in 2013[70] found that 47% of respondents used both Clojure and ClojureScript when working with Clojure. In 2014 this number had increased to 55%,[71] in 2015, based on 2,445 respondents, to 66%.[72] Popular ClojureScript projects include implementations of the React library such as Reagent[73] and Om.[74][75]

Clojure has also been used for creative computing, including visual art, music, games, and poetry.[76]

A growing number of unofficial and experimental implementations for other platforms testify to the popularity of the language:

  • las3r,[77] a subset of Clojure that runs on the ActionScript Virtual Machine (the Adobe Flash Player platform)
  • clojure-py,[78] Clojure in pure Python
  • rouge,[79] Clojure atop YARV in Ruby
  • CljPerl,[80] Clojure atop Perl
  • Pixie, Clojure-inspired Lisp dialect written in RPython
  • Ferret,[81] compiles to self-contained C++11 that can run on microcontrollers
  • Joker,[82] an interpreter and linter written in Go
  • clojerl,[83] Clojure on the Erlang VM


Hello, World! program

(println "Hello, World!")

Programming at REPL

Like other Lisps, one of the iconic features of Clojure is interactive programming at the REPL.[84] Note that, in the following examples, ";;" starts a line comment and ";; =>" indicates output:

;; define a var
(def a 42)
;; => #'user/a

;; call a function named `+`
(+ a 8)
;; => 50

;; call a function named `even?`
(even? a)
;; => true

;; define a function that returns the remainder of `n` when divided by 10
(defn foo [n] (rem n 10))
;; => #'user/foo

;; call the function
(foo a)
;; => 2

;; print the docstring of `rem`
(doc rem)
;; =>
([num div])
 remainder of dividing numerator by denominator.

;; print the source of `rem`
(source rem)
;; =>
(defn rem
  "remainder of dividing numerator by denominator."
  {:added "1.0"
   :static true
   :inline (fn [x y] `(. clojure.lang.Numbers (remainder ~x ~y)))}
  [num div]
    (. clojure.lang.Numbers (remainder num div)))

Names at runtime

Unlike other runtime environments where names get compiled away, Clojure's runtime environment is easily introspectable using normal Clojure data structures:

;; define a var
(def a 42)
;; => #'user/a

;; get a map of all public vars interned in the `user` namespace
(ns-publics 'user)
;; => {a #'user/a}

;; reference the var via `#'` (reader macro) and
;; its associated, namespace-qualified symbol `user/a`
;; => #'user/a

;; de-reference (get the value of) the var
(deref #'user/a)
;; => 42

;; define a function (with a docstring) that
;; returns the remainder of `n` when divided by 10
(defn foo "returns `(rem n 10)`" [n] (rem n 10))
;; => #'user/foo

;; get the metadata of the var `#'user/foo`
(meta #'user/foo)
;; =>
{:arglists ([n]),
 :doc "returns `(rem n 10)`",
 :line 1,
 :column 1,
 :file "user.clj",
 :name foo,
 :ns #namespace[user]}

Code as data (homoiconicity)

Similar to other Lisps, Clojure is homoiconic (also known as code as data). In the example below, we can see how easy it is to write code that modifies code itself:

;; call a function (code)
(+ 1 1)
;; => 2

;; quote the function call
;; (turning code into data, which is a list of symbols)
(quote (+ 1 1))
;; => (+ 1 1)

;; get the first element on the list
;; (operating on code as data)
(first (quote (+ 1 1)))
;; => +

;; get the last element on the list
;; (operating on code as data)
(last (quote (+ 1 1)))
;; => 1

;; get a new list by replacing the symbols on the original list
;; (manipulating code as data)
(map (fn [form]
       (case form
         1 'one
         + 'plus))
     (quote (+ 1 1)))
;; => (plus one one)

Expressive operators for data transformation

The threading macros (->, ->>, and friends) can syntactically express the abstraction of piping a collection of data through a series of transformations:

(->> (range 10)
  (map inc)
  (filter even?))
;; => (2 4 6 8 10)

This can also be achieved more efficiently using transducers:

(into []
      (comp (map inc)
            (filter even?))
      (range 10))
;; => [2 4 6 8 10]

Thread-safe identity management

A thread-safe generator of unique serial numbers (though, like many other Lisp dialects, Clojure has a built-in gensym function that it uses internally):

(def i (atom 0))

(defn generate-unique-id
  "Returns a distinct numeric ID for each call."
  (swap! i inc))


An anonymous subclass of that doesn't write to anything, and a macro using it to silence all prints within it:

(def bit-bucket-writer
  (proxy [] []
    (write [buf] nil)
    (close []    nil)
    (flush []    nil)))

(defmacro noprint
  "Evaluates the given `forms` with all printing to `*out*` silenced."
  [& forms]
  `(binding [*out* bit-bucket-writer]

  (println "Hello, nobody!"))
;; => nil

Java interoperability

Clojure was created from ground up to embrace its host platforms as one of its design goals therefore has excellent support for interoperability with Java:

;; call an instance method
(.toUpperCase "apple")
;; => APPLE

;; call a static method
(System/getProperty "java.vm.version")
;; => 11+28-201810022317

;; create an instance of `java.util.HashMap` and
;; add some entries
(doto (java.util.HashMap.)
  (.put "apple" 1)
  (.put "banana" 2))
;; => {apple=1, banana=2}

;; create an instance of `java.util.ArrayList` and
;; increment its elements with `clojure.core/map`
(def al (doto (java.util.ArrayList.)
          (.add 1)
          (.add 2)
          (.add 3)))

(map inc al)
;; => (2 3 4)

;; show a message dialog using Java Swing
  "Hello, World!")
;; => nil

Software transactional memory

10 threads manipulating one shared data structure, which consists of 100 vectors each one containing 10 (initially sequential) unique numbers. Each thread then repeatedly selects two random positions in two random vectors and swaps them. All changes to the vectors occur in transactions by making use of Clojure's software transactional memory system:

(defn run
  [nvecs nitems nthreads niters]
  (let [vec-refs
        (->> (* nvecs nitems)
          (partition nitems)
          (map (comp ref vec))

        #(let [v1 (rand-int nvecs)
               v2 (rand-int nvecs)
               i1 (rand-int nitems)
               i2 (rand-int nitems)]
            (let [tmp (nth @(vec-refs v1) i1)]
              (alter (vec-refs v1) assoc i1 (nth @(vec-refs v2) i2))
              (alter (vec-refs v2) assoc i2 tmp))))

        #(let [derefed (map deref vec-refs)]
          (prn derefed)
          (println "Distinct:" (->> derefed
                                 (apply concat)
    (->> #(dotimes [_ niters] (swap))
      (repeat nthreads)
      (apply pcalls)

(run 100 10 10 100000)
;; =>
([0 1 2 3 4 5 6 7 8 9] [10 11 12 13 14 15 16 17 18 19] ...
 [990 991 992 993 994 995 996 997 998 999])
 Distinct: 1000

([382 318 466 963 619 22 21 273 45 596] [808 639 804 471 394 904 952 75 289 778] ...
 [484 216 622 139 651 592 379 228 242 355])
 Distinct: 1000


Tooling for Clojure development has seen significant improvement over the years. The following is a list of the most popular IDEs/editors with their plug-ins that combined provide excellent support for Clojure development:[85]

In addition to the tools provided by the community, the official CLI tools have also become available on GNU/Linux and macOS since Clojure 1.9.

Getting the Official Clojure CLI Tools
Operating System Package Manager Commands
GNU/Linux (N/A) curl -O
chmod +x
sudo ./
macOS Homebrew brew update
brew install clojure
Windows (N/A) (not available yet - see Leiningen or Boot instead)

See also


  1. ^ "Index of /maven2/org/clojure/clojure/1.9.0/". 2017-12-08. Retrieved .
  2. ^ Fogus, Michael. "Rich Hickey Q&A". Retrieved .
  3. ^ Hickey, Rich. "Clojure Bookshelf". Listmania!. Retrieved .
  4. ^ Bonnaire-Sergeant, Ambrose (2012). A Practical Optional Type System for Clojure (Thesis). The University of Western Australia.
  5. ^ "Clojure Programming" (PDF). Retrieved .
  6. ^ Hickey, Rich. "meaning and pronunciation of Clojure". Google Groups. Retrieved .
  7. ^ a b Krill, Paul. "Clojure inventor Hickey now aims for Android". Retrieved .
  8. ^ a b "Clojure - home". Retrieved .
  9. ^ "Clojure - Lisp". Retrieved .
  10. ^ a b "Contributing FAQ - Clojure Community - Clojure Development". Retrieved .
  11. ^ "Clojure - funding". Retrieved .
  12. ^ "clojure/core.typed". GitHub. Retrieved .
  13. ^ a b "Clojure - state". Retrieved .
  14. ^ a b Hickey, Rich. "Rationale". Retrieved .
  15. ^ a b Charles (2009-10-06). "Expert to Expert: Rich Hickey and Brian Beckman - Inside Clojure; Going Deep; Channel 9". Retrieved .
  16. ^ "JUXT Blog: Clojure in London: Funding Circle". Retrieved .
  17. ^ "Walmart Runs Clojure at Scale". Retrieved .
  18. ^ "A New Era of Application Services at Puppet Labs". Puppet Labs. Retrieved .
  19. ^ "Roman Liutikov at Twitter". Twitter. Retrieved .
  20. ^ "Jobs at Apple". Apple Inc. Retrieved .
  21. ^ "Clojure - Success Stories". Retrieved .
  22. ^ "Clojure Programming Language: Cognitect, Clojure Consulting, Clojure Support, Functional Programming, JVM". Retrieved .
  23. ^ Clojure/conj
  24. ^ Clojure/West
  25. ^ EuroClojure
  26. ^ "[ANN] dotLisp - a Lisp dialect for .Net". Google Groups.
  27. ^ "jfli, a Java foreign language interface for Common Lisp".
  28. ^ "Foil - a Foreign Object Interface for Lisp".
  29. ^ "Lisplets - a Lisp-friendly interface to Java Servlets".
  30. ^ Clojure Community website
  31. ^ Clojure Dev Google Group
  32. ^ "Contributing FAQ - Clojure Community - Clojure Development". Retrieved .
  33. ^ "JIRA workflow - Clojure Community - Clojure Development". Retrieved .
  34. ^ "Economy Size Geek - Interview with Rich Hickey, Creator of Clojure". Linux Journal. Retrieved .
  35. ^ a b Hickey, Rich. "On State and Identity". Retrieved .
  36. ^ "Clojure: Clojure is Two!". Clojure Blog. Retrieved .
  37. ^ a b c d e f Fingerhut, Andy. "Clojure version history". Retrieved .
  38. ^ "Clojure: Clojure 1.0". Clojure Blog. Retrieved .
  39. ^ "Clojure: Clojure 1.1 Release". Retrieved .
  40. ^ "Clojure - protocols". Retrieved .
  41. ^ "Clojure/clojure". GitHub. Retrieved .
  42. ^ "Google Groups". Retrieved .
  43. ^ a b "Clojure 1.9". Cognitect. Retrieved .
  44. ^ "Google Groups". Retrieved .
  45. ^ "Google Groups". Retrieved .
  46. ^ a b "Clojure - jvm_hosted". Retrieved .
  47. ^ "Clojure - java_interop". Retrieved .
  48. ^ a b Hagelberg, Phil; contributors. "Leiningen". Retrieved .
  49. ^ a b c "Clojure - reader". Retrieved .
  50. ^ "Clojure - Lisps". Retrieved .
  51. ^ "Clojure - macros". Retrieved .
  52. ^ Hickey, Rich. "edn". GitHub. Retrieved .
  53. ^ "Clojure - multimethods". Retrieved .
  54. ^ "Clojure - protocols". Retrieved .
  55. ^ "Clojure - datatypes". Retrieved .
  56. ^ Goetz, Brian. "Brian Goetz - Stewardship: the Sobering Parts". YouTube: ClojureTV. Retrieved .
  57. ^ Rose, John. "tail calls in the VM". Retrieved .
  58. ^ Rose, John. "Some languages need to be able to perform tail calls". JDK Bug System. Retrieved .
  59. ^ "Clojure - special_forms". Retrieved .
  60. ^ "Clojure - Refs". Retrieved .
  61. ^ "Clojure - Agents". Retrieved .
  62. ^ "Clojure: Clojure core.async Channels". Retrieved .
  63. ^ "Clojure - reader". Retrieved .
  64. ^ "Transducers" by Rich Hickey. Retrieved on 2015-09-15.
  65. ^ "Transducers are Coming". Retrieved .
  66. ^ "Rich Hickey - Inside Transducers". YouTube: Cognitect Inc. 2014-11-20. Retrieved .
  67. ^ "Clojure/Clojurescript". GitHub. Retrieved .
  68. ^ "ClojureScript - FAQ (for JavaScript developers)". Retrieved .
  69. ^ "clojure/clojure-clr". GitHub. Retrieved .
  70. ^ Emerick, Chas. "Results of the 2013 State of Clojure & ClojureScript survey". Cemerick. Retrieved .
  71. ^ "State of Clojure 2014 Survey Results". Cognitect Blog. Retrieved .
  72. ^ "State of Clojure 2015 Survey Results". Cognitect Blog. Retrieved .
  73. ^ "Reagent". GitHub.
  74. ^ "Om". GitHub.
  75. ^ "Om: Enhancing Facebook's React with Immutability". InfoQ. Retrieved .
  76. ^ Meier, Carin. "Creative computing with Clojure". O'Reilly Radar. Retrieved .
  77. ^ aemoncannon (2010-12-30). "Home: aemoncannon/las3r Wiki". GitHub. Retrieved .
  78. ^ "drewr/clojure-py". GitHub. Retrieved .
  79. ^ "rouge-lang/rouge". GitHub. Retrieved .
  80. ^ "A Lisp on Perl". MetaCPAN. Retrieved .
  81. ^ "Ferret". GitHub.
  82. ^ "Joker". GitHub.
  83. ^ "clojerl". GitHub.
  84. ^ "Programming at the REPL: Introduction". Retrieved .
  85. ^ Miller, Alex. ""State of Clojure 2018" Results". Retrieved .

Further reading

External links



Community-driven documentation



Online REPLs

  This article uses material from the Wikipedia page available here. It is released under the Creative Commons Attribution-Share-Alike License 3.0.



Connect with defaultLogic
What We've Done
Led Digital Marketing Efforts of Top 500 e-Retailers.
Worked with Top Brands at Leading Agencies.
Successfully Managed Over $50 million in Digital Ad Spend.
Developed Strategies and Processes that Enabled Brands to Grow During an Economic Downturn.
Taught Advanced Internet Marketing Strategies at the graduate level.

Manage research, learning and skills at Create an account using LinkedIn to manage and organize your omni-channel knowledge. is like a shopping cart for information -- helping you to save, discuss and share.

  Contact Us