Groovy 1.6.0 BETA 1 发布了!性能有显著提升!

转载自:蛟龍居 山不在高,有仙則名;水不在深,有龍則靈
<a href="http://www.blogjava.net/BlueSUN/archive/2008/05/03/197863.html">链接</a>
[b]文章中提到的性能提高,本人做过实验,的确提高很多。[/b]

Groovy 1.6.0 BETA 1终于发布了,除了一些BUG修正外,最令人兴奋的是,Groovy的运行效率有了显著的提升。官方用Great Language Shootout的基准测试得出Groovy 1.6.0 BETA 1的性能相比Groovy 1.5.6 GA,提升了150%~460%。

眼见为实,耳听为虚,我自己也做了一个相对简单的性能测试:

利用Groovy 1.6.0 BETA 1将下面解决八皇后问题的代码执行10次,结果如下:
1 2 3 4 5 6 7 8 9 10 AVG
Groovy1.5.6GA : 1360 1156 969 1000 1063 1110 938 1046 1031 954 1062.7
Groovy1.6.0BETA1: 187 171 141 109 187 156 172 141 203 187 165.4

经过计算,Groovy1.6.0BETA1的性能相比Groovy1.5.6GA,提升了542.5%。

如果是普通应用程序代码的话,提升的幅度会小一点。


此外,Groovy1.6.0BETA1还支持Multiple assignments(多重赋值)
def listOfN(numOfElem) {
1..numOfElem
}

def a, b
[a, b] = listOfN(1)
assert a == 1
assert b == null

[a, b] = listOfN(10)
assert a == 1
assert b == 2

[a, b] = [b, a]
assert a == 2
assert b == 1

还支持Annotations的定义,(在Groovy 1.6.0之前,Annotations的定义只能放在Java代码中):
@interface Cachable {
String cache()
}
最后一个值得关注的新特性就是引入@Bindable这个Annotation
具体使用方法请参考: Groovy高效编程——@Bindable的使用


八皇后问题代码:
[i]q = 8
i = new int[q]
count = 0

def scan(n){
if (n == q){
println(i.toList())
count++
return
}
i[n]=0
while (i[n] < q){
i[n] = i[n]+1
if (check(n))
scan(n + 1)
}
}
def check(n){
if (n > 0)
for (j in 0..<n)
if (i[j] == i[n] || i[j] - i[n] == j - n || i[j] - i[n] == n - j)
return false
return true
}

long t1 = System.currentTimeMillis()
scan(0)
long t2 = System.currentTimeMillis()
println("total time:" + ( t2 - t1)) // 耗时
println("total results:" + count)[/i]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值