阅读更多

13顶
0踩

编程语言

原创新闻 Clojure - Java平台的Erlang

2007-10-21 11:22 by 见习编辑 robbin 评论(4) 有19793人浏览
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整合示例:

(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/
13
0
评论 共 4 条 请登录后发表评论
4 楼 ddkk 2011-11-07 10:49
Arbow 写道
感觉仅仅是基于jvm平台的函数式语言,scala比它更加完善

Java整合示例中的代码让我眼前一亮
scala中也有类似的语法吗?
3 楼 billgui 2009-01-02 15:38
除了多核CPU,Clojure是否支持多机集群呢?Erlang可以很方便地支持多机集群的。
2 楼 sp42 2007-10-22 18:55
说到jvm上FP,JAVA 1.6 的rhino 本身就是 FP的一种...
1 楼 Arbow 2007-10-21 19:43
感觉仅仅是基于jvm平台的函数式语言,scala比它更加完善

发表评论

您还没有登录,请您登录后再发表评论

相关推荐

Global site tag (gtag.js) - Google Analytics