Groovy高效编程——‘匕首方法’的使用
Groovy提供了许多‘匕首方法’(匕首,短小精悍也~如each,eachWithIndex, any,every,grep,join,sort,find,findAll,collect,groupBy,inject,reverse, tokenize,unique,max,min,count,sum等)来提升开发者的开发效率,但常被Java开发人员忽视。在这篇随笔中我将为您演示各方法的使用。 each 遍历list
运行结果: 遍历map 运行结果: name : 山风小子 eachWithIndex 带index的each list.eachWithIndex { elem,i -> |
运行结果:
0 : a
1 : b
2 : c
any
只要存在一个满足条件(此例中的条件为elem.length() < 3)的element就返回true,否则返回false
运行结果:
true
every
所有的element都满足条件才返回true,否则返回false
list.every { elem ->
elem.length() < 3
}
运行结果:
false
grep
符合条件的element会被提取出来,形成一个list
条件以closure的形式传入
list.grep { elem ->
elem.length() < 3
}
运行结果:
["a","ab"]
条件以regex的形式传入,符合regex的element被提取出来形成一个list
list.grep(~/../)
运行结果:
["ab"]
条件以collection的形式传入,在collection中的element被提取出来形成一个list,可以看作求两个collection的交集
list.grep(['a','cde','ab'])
运行结果:
["a","ab"]
join
用指定的字符连接collection中的element
def list = [2007,8,26]
list.join('-')
2007-8-26
sort
根据指定条件进行排序
list.sort { e1,e2 ->
return e1 - e2
}
[8,26,2007]
find
查找collection中满足条件的‘第一个’element
list.find { elem ->
elem <30
}
8
findAll
查找collection中满足条件的‘所有’element
list.findAll { elem ->
elem < 30
}
collect
对collection的element进行处理,并将处理结果放到一个新的collection中
list.collect { elem ->
elem * 2
}
["aa","bb","cc"]
对map进行处理
groupBy
对collection中的element按给定条件进行分组
inject
一个累积的过程,传入inject方法的'I'作为sum的初始值,在遍历collection的过程中,将处理结果("$sum $elem ")保存到sum中
I love? you
reverse
将collection中各element的次序颠倒一下
list.reverse()
["c","a"]
颠倒字符串
cba
tokenize
指定分隔符,取得token集
["a1","b2","c3","d4"]
unique
去除collection中重复的element
max
求最大值
3
按指定的比较内容(此例的比较内容为长度length),在collection中选出最大的element
list.max { elem ->
elem.length()
}
min与max类似,求最小值,再次就不演示用法了,用法与max相同,将上述代码中的max改为min即可
count
计数
对字符串"aaba"中的a进行计数
def list = "aaba"
list.count('a')
sum
求和
6
求字符串的‘和’,其实就是连接字符串
abc
最后,我想提醒各位一点:有时您可以将string看作list,对string使用适用于list的‘匕首方法’。
来源?http://developer.51cto.com/art/200710/58074.htm
(编辑:李大同)
【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!