
为什么要学 Groovy
Groovy 运行于 JVM 之上,然而其对动态语言、函数式编程范式以及元编程功能的加持所带来的表现力和简洁性可以说甩了 Java 几条街。我们可以利用 Groovy 的所有动态功能构建高性能的 JVM 应用、将开发效率提高几个数量级! 再比如说我们用的 CI 系统 Jenkins,其 Pipeline 的编排 Jenkinsfile 文件就是用 Groovy 来书写,除此之外还有很多应用 Groovy 的地方。这就是我们为什么要学它!
Groovy 环境部署
本文实验所用 OS 为 CentOS7,这里介绍使用 sdk 工具来安装 Groovy 的方法。
- 首先在命令行下执行:
curl -s get.sdkman.io | bash

- 接下来执行:
source "$HOME/.sdkman/bin/sdkman-init.sh"
- 然后我们就可以使用 sdk 工具来安装 Groovy:
一句话搞定!
sdk install groovy

- 完成之后我们来检查 Groovy 安装状态
groovy -v
一切就绪

Hello World From Groovy
[root@localhost ~]# vim Hello.groovy
[root@localhost ~]# more Hello.groovy
println "Hello World From Groovy !"
[root@localhost ~]# groovy Hello
Hello World From Groovy !
Groovy 语言特性
- Groovy 是轻量级的 Java
- Groovy 的信噪比比 Java 高:较少的代码获得更多结果
- GDK = Groovy JDK:通过向 JDK 的各种类中添加便捷方法,Groovy 扩展了 JDK 形成了 GDK 库
- return 语句可选,分号结尾可选
- 方法和类默认 public
- 导航操作符可帮助实现对象引用不为空时方法才会被调用
- Groovy 不强迫捕获自己不关心的异常,没捕获的异常自动传到高层
- 静态方法内可使用 this 来引用 Class 对象,因此可以链式调用!
两大优点:表现力 + 简洁!!!
从 Java 到 Groovy
用 Java 写一段代码如下:
public class Greetingss {
public static void main( String[] args ) {
for( int i=0; i<3; i++ ) {
System.out.println("ho ");
}
System.out.println("Merry Groovy");
}
}
用 Groovy 重构一遍如下:
for(i in 0..2) {
print 'ho '
}
print 'Merry Groovy'
看看两种语言的信噪比对比,真是给人不可估量的感动!
安全导航操作符 ?.
可以避免代码中的大量 null 引用的判断
def foo( str ) {
str?.reverse() // 仅当 str 不为 null 时 reverse 才会执行
}
这可以帮我们省多少个if啊!!!
异常处理
与 Java 相比,Groovy 的异常处理少了很多繁文缛节
对于那些不想处理或者不适合在代码当前层次处理的异常,Groovy 对用户不做任何要求,任何用户未处理的异常会自动传递到高一层,我们啥也不用写:
def openfile( fileName ) { // 无需 throws
new FileInputStream( fileName ) // 无需 try...catch... 处理
}
异常可以放到其调用代码中处理:
try {
openFile("nonexistfile")
} catch( FileNotFoundException ex ) {
print "Oops: " + ex
}
若捕获所有异常( Exception ),则上面 catch 中异常的类型都可省略:
try {
openFile("nonexistfile")
} catch( ex ) { // 省略类型表示可捕获所有异常
print "Oops: " + ex
}
链式调用
静态方法内可使用 this 来引用 Class 对象,因此可以链式调用
class Wizard {
def static learn( trick, action ) {
//...
this
}
}
Wizard.learn('xxxx', {...})
.learn('yyyy', {...})
.learn('zzzz', {...})