Zum Inhalt springen

Clojure

aus Wikipedia, der freien Enzyklopädie
Dies ist eine alte Version dieser Seite, zuletzt bearbeitet am 31. Mai 2020 um 10:42 Uhr durch 109.193.97.68 (Diskussion) (Merkmale von Clojure: Siehe Duden Grammatik). Sie kann sich erheblich von der aktuellen Version unterscheiden.
Clojure
Clojure Logo
Basisdaten
Paradigmen: Funktionale Programmiersprache
Erscheinungsjahr: 2007
Entwickler: Rich Hickey
Aktuelle Version: 1.10.1[1]  (6. Juni 2019)
Typisierung: dynamisch, stark
Beeinflusst von: Lisp, Prolog, ML, Erlang, Haskell, Java[2]
Betriebssystem: Windows, Linux, macOS, Solaris, FreeBSD
Lizenz: Eclipse Public License
https://clojure.org/

Clojure [ˈkləʊʒə(r)] ist ein moderner Lisp-Dialekt, der interaktive Entwicklung unterstützt. Die Sprache fördert einen funktionalen Stil, der nebenläufige Programmierung stark vereinfacht. Clojure läuft in der Java Virtual Machine und ist eng mit der Java Runtime integriert. Eine JavaScript-Implementierung mit dem Namen ClojureScript sowie eine CLR-Implementierung existieren ebenso. Das Makrosystem ist mit dem anderer Lisp-Umgebungen vergleichbar.

Clojure-Projekte werden häufig mithilfe von Leiningen verwirklicht.[3]

Beispiele

Vollständige Hallo-Welt-Programme:

textuell im Lisp-Stil:

(println "Hallo Welt!")

grafisch mit Hilfe der Java-Bibliothek Swing:

(javax.swing.JOptionPane/showMessageDialog nil "Hallo Welt!")

Die Fakultäts-Funktion als Beispiel für Rekursion in Clojure:

(defn factorial [n]
  "tail recursive version of n!"
  (loop [cur n, acc 1]
    (if (<= cur 1)
      acc
      (recur (dec cur) (*' cur acc)))))

Die Fakultäts-Funktion durch Verwendung von Funktionen höherer Ordnung:

(defn fac [n]
  (reduce *' (range 1 (inc n))))

Merkmale von Clojure

  • Funktionale Sprache mit einer Lisp-Syntax.
  • Dynamische, interaktive Entwicklung in der REPL (Read-eval-print loop).
  • Neben der in Lisp klassischen Liste unterstützt die Syntax Vektoren, assoziative Arrays und Mengen.
  • Die Abstraktion der Folge (sequence) erlaubt es, alle diese Datenstrukturen uniform mit denselben Funktionen zu verwenden. Folgen werden typischerweise verzögert (lazy) ausgewertet.
  • Alle Datenstrukturen sind Werte (immutable).
  • Zustandsbehaftete Daten werden in Clojure durch spezielle Typen realisiert (atoms und refs). Der konkurrierende Zugriff auf Variablen mit veränderlichen Werten wird mittels STM (software transactional memory) durch das Laufzeitsystem der Sprache synchronisiert. Die Konzepte entsprechen der Multiversion Concurrency Control, wie sie in Datenbankmanagementsystemen verwendet werden (exakt so wie in Oracle).
  • Clojure wird zu Java-Bytecode kompiliert und in der Java Virtual Machine ausgeführt. Dadurch ist es möglich, in Clojure jede beliebige Java-Bibliothek zu verwenden, und für sehr viele von diesen gibt es (oft schmale) Wrapper-Bibliotheken in Clojure.
  • Neben Clojure gibt es ClojureScript, eine Sprache, die Konzept und Syntax mit Clojure teilt. Clojurescript wird zu JavaScript kompiliert.

Homoikonizität

Als Lisp-Dialekt spielt das Prinzip Code als Daten bzw. Homoikonizität eine wichtige Rolle. Das Makrosystem von Clojure beruht auf dieser Eigenschaft und erlaubt so Metaprogrammierung. Konkret kann Clojure davon profitieren, indem es Eigenschaften, die in anderen Programmiersprachen fest integriert sind, als Bibliotheken zur Verfügung stellt. Als Beispiele seien hier Pattern Matching[4] und ein Typsystem[5] genannt.

IDE-Unterstützung

Literatur

Wikibooks: Clojure Programming – Lern- und Lehrmaterialien (englisch)

Einzelnachweise

  1. github.com
  2. Rich Hickey: Books that influenced Clojure. 30. Juni 2009, abgerufen am 24. August 2010.
  3. leiningen.org
  4. github.com
  5. github.com
  6. Light Table
  7. Cursive
  8. Counterclockwise
  9. vsClojure
  10. Clojure-Mode
  11. CIDER
  12. VimClojure