1、 集合
(1)List (java.util.List)
list = [1,2,'hello',new java.util.Date()]
assert list.size() == 4
assert list.get(2) == 'hello'
注意:一切都是对象(数字会自动转换)
(2)Map (java.util.Map)
map = ['name':'James','location':'London']
assert map.size() == 2
assert map.get('name') == 'James'
(3)遍历集合
list = [1,3]
for (i in list) { println i }
2、 闭包(Closures)
l 闭包类似Java的内类,区别是闭包只有单一的方法可以调用,但可以有任意的参数
closure = { param | println("hello ${param}") }
closure.call("world!")
closure = { greeting,name | println(greeting + name) }
closure.call("hello ","world!")
l 闭包用“{}”括起,“|”前面是参数,后面是处理语句,使用call调用
l 第一个例子演示了在字符串内使用参数的形式:${param}
l 第二个例子演示了多参数形式:用“,”分隔参数
l 如果只有一个参数,可以不写,而使用缺省的参数“it”,如下面的例子:
closure = { println "hello " + it }
closure.call("world!")
3、 each
l 遍历集合,逐个传递给闭包
[1,3].each { item | print "${item}-" }
l 上面例子的输出结果是:1-2-3-
4、 collect
l 遍历集合,逐个传递给闭包,处理后的结果返回给对应的项
value = [1,3].collect { it * 2 }
assert value == [2,4,6]
5、 find
l 根据闭包断言,返回集合中找到的第一个项目
value = [1,3].find { it > 1 }
assert value == 2
6、 findAll
l 根据闭包断言,返回集合中所有找到的项目
value = [1,3].findAll { it > 1 }
assert value == [2,3]
7、 inject
l 遍历集合,第一次将传递的值和集合项目传给闭包,将处理结果作为传递的值,和下一个集合项目传给闭包,依此类推
value = [1,3].inject('counting: ') { str,item | str + item }
assert value == "counting: 123"
value = [1,3].inject(0) { count,item | count + item }
assert value == 6
8、 every
l 如果集合中所有项目都匹配闭包断言,就返回true,否则返回false
value = [1,3].every { it < 5 }
assert value
value = [1,3].every { item | item < 3 }
assert ! value
9、 any
l 如果集合中任何项目匹配闭包断言,就返回true,否则返回false
value = [1,3].any { it > 2 }
assert value
value = [1,3].any { item | item > 3 }
assert value == false
10、 min/max
l 返回集合中的最小/最大项目(对象必须可比较)
value = [9,10,5].max()
assert value == 10
value = [9,5].min()
assert value == 2
value = ['x','y','a','z'].min()
assert value == 'a'
11、 join
l 连接集合中的值成一个字符串
value = [1,3].join('-')
assert value == '1-2-3'
12、 yield
l 在Python和Ruby中通过yield语句创建“yield”风格的iterators,在Groovy同样有效,只是使用的是闭包
class Foo{
static void main(args) {
foo = new Foo()
for (x in foo.myGenerator) {
print("${x}-")
}
}
myGenerator(Closure yield) {
yield.call("A")
yield.call("B")
yield.call("C")
}
}
l 例子的输出结果是:A-B-C-
l Cloures原型可以省略,call和括号同样可选,这样更象Python/Ruby
class Foo {
myGenerator(yield) {
yield "A"
yield "B"
yield "C"
}
static void main(args) {
foo = new Foo()
foo.myGenerator { println "Called with ${it}" }
}
}