声明:JavaEye新闻文章的版权属于JavaEye网站所有,严禁任何网站转载本文,否则必将追究法律责任!
Erlang是近两年非常吸引眼球的函数式编程语言,因为Erlang能够做到code-as-data,以及数据不变的特性,因此非常适合大规模,高并发负载的应用环境。特别是随着现在多核CPU的广泛应用,并行运算成为了一个热点话题。
作为当今最主流的运算平台JVM,把函数式编程语言引入JVM也是很多人尝试的方向,Clojure就是其中之一。Clojure是一个在JVM平台运行的动态函数式编程语言,其语法解决于LISP语言,在JVM平台运行的时候,会被编译为JVM的字节码进行运算。
Clojure保持了函数式语言的主要特点,例如immutable state,Full Lisp-style macro support,persistent data structures等等,并且还能够非常方便的调用Java类库的API,和Java类库进行良好的整合。
Java整合示例:
Lisp风格的宏
也许,Clojure将成为JVM平台的Erlang,想想看,Clojure还能够直接调用Java的类库,真是令人兴奋。
Clojure的主页:
http://clojure.sourceforge.net/
作为当今最主流的运算平台JVM,把函数式编程语言引入JVM也是很多人尝试的方向,Clojure就是其中之一。Clojure是一个在JVM平台运行的动态函数式编程语言,其语法解决于LISP语言,在JVM平台运行的时候,会被编译为JVM的字节码进行运算。
Clojure保持了函数式语言的主要特点,例如immutable state,Full Lisp-style macro support,persistent data structures等等,并且还能够非常方便的调用Java类库的API,和Java类库进行良好的整合。
Java整合示例:
(new java.util.Date) => Wed Oct 17 20:01:38 CEST 2007 (. (new java.util.Date) (getTime)) => 1192644138751 (.. System out (println "This is cool!")) This is cool!
Lisp风格的宏
(defmacro time [form]
`(let [t0# (. System (currentTimeMillis))
res# ~form
t1# (. System (currentTimeMillis))]
(.. System out (println (strcat "Execution took "
(/ (- t1# t0#) 1000.0) " s")))
res#))
Usage:
(defn factorial [n]
(if (< n 2)
1
(* n (factorial (- n 1)))))
(time (factorial 1000))
=> Execution took 0.012 s
40…
也许,Clojure将成为JVM平台的Erlang,想想看,Clojure还能够直接调用Java的类库,真是令人兴奋。
Clojure的主页:
http://clojure.sourceforge.net/


评论 共 2 条 发表评论
sp42 2007-10-22 18:55
Arbow 2007-10-21 19:43