public
Method&Field默认是public的
Range
def repeat(val){
for(i in 0..5){
println val
}
}
上面的代码将打印6次,原因是前后都是close的
默认参数值
def repeat(val, repeat=5){
for(i in 0..<repeat){
println val
}
}
List
def
def range = 0..4
def coll = ["Groovy", "Java", "Ruby"]
modify
coll.add("Python")
coll << "Smalltalk"
coll[5] = "Perl"
modify collection
def numbers = [1,2,3,4]
assert numbers + 5 == [1,2,3,4,5]
assert numbers - [2,3] == [1,4]
join&count
def numbers = [1,2,3,4]
assert numbers.join(",") == "1,2,3,4"
assert [1,2,3,4,3].count(3) == 2
注意count是查找一个元素出现个数,这也意味着这个方法对List是有用的,对于Set恐怕就没啥用了
forEach
assert ["JAVA", "GROOVY"] ==
["Java", "Groovy"]*.toUpperCase()
Map
def hash = [name:"Andy", "VPN-#":45]
这个示例中,name 看起来像一个变量,但是在幕后,Groovy 会将它变成 String。
Map <=> Bean
hash.dob = "01/29/76"
assert hash.dob == "01/29/76"
上面把hash这个Map当成一个Bean来处理
JS like
assert hash["name"] == "Andy"
hash["gender"] = "male"
assert hash.gender == "male"
assert hash["gender"] == "male"
${}
def hash = [name:"Andy", "VPN-#":45]
hash.each{ key, value ->
println "${key} : ${value}"
}
闭包
def excite = { word ->
return "${word}!!"
}
assert "Groovy!!" == excite("Groovy")
assert "Java!!" == excite.call("Java")
下面这种写法就和FunctionalInterface很像了
构造函数
def sng2 = new Song(name:"Kung Fu Fighting", genre:"Disco")
()
sng3.setGenre "Disco"
assert sng3.genre == "Disco"
正如上面例子所演示的对于接受参数的方法,可以省略括号
return
String toString(){
"${name}, ${artist}, ${genre}"
}
正如上面例子所演示的在 Groovy 中可以省略 return 语句。Groovy 默认返回方法的最后一行。
null ?
Groovy 通过 ? 操作符提供了一个安全网 — 在方法调用前面添加一个 ? 就相当于在调用前面放了一个条件,可以防止在 null 对象上调用方法。