Groovy初体验:构建高性能JVM应用

简介: Groovy运行于JVM之上,然而其对**动态语言**、**函数式编程范式**以及**元编程功能**的加持所带来的表现力和简洁性可以说甩了Java几条街。我们可以利用Groovy的所有动态功能构建高性能的JVM应用、将开发效率提高几个数量级!

VAIO王者归来


为什么要学Groovy

Groovy运行于JVM之上,然而其对动态语言函数式编程范式以及元编程功能的加持所带来的表现力和简洁性可以说甩了Java几条街。我们可以利用Groovy的所有动态功能构建高性能的JVM应用、将开发效率提高几个数量级! 这就是我们为什么要学它!


Groovy环境部署

本文实验所用OS为CentOS7,这里介绍使用sdk工具来安装Groovy的方法。

  • 首先在命令行下执行:

curl -s get.sdkman.io | bash

炫酷得一腿!

  • 接下来执行:

source "$HOME/.sdkman/bin/sdkman-init.sh"

  • 然后我们就可以使用sdk工具来安装Groovy:

一句话搞定!

sdk install groovy

sdk install

  • 完成之后我们来检查Groovy安装状态

groovy -v

一切就绪

image.png


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', {...})

后记

作者更多的原创文章在此:

https://www.jianshu.com/u/d19536b0189b

目录
相关文章
|
11月前
【面试题精讲】JVM-类加载器-应用场景
【面试题精讲】JVM-类加载器-应用场景
|
4月前
|
存储 Java 数据库
jvm性能调优 - 06线上应用部署JVM实战_堆内存预估与设置
jvm性能调优 - 06线上应用部署JVM实战_堆内存预估与设置
98 0
|
26天前
|
算法 Java 应用服务中间件
探索JVM垃圾回收算法:选择适合你应用的最佳GC策略
探索JVM垃圾回收算法:选择适合你应用的最佳GC策略
|
26天前
|
存储 监控 算法
深入解析JVM内部结构及GC机制的实战应用
深入解析JVM内部结构及GC机制的实战应用
|
2月前
|
弹性计算 运维 Java
Serverless 应用引擎使用问题之JVM进行垃圾回收时重启,该如何解决
阿里云Serverless 应用引擎(SAE)提供了完整的微服务应用生命周期管理能力,包括应用部署、服务治理、开发运维、资源管理等功能,并通过扩展功能支持多环境管理、API Gateway、事件驱动等高级应用场景,帮助企业快速构建、部署、运维和扩展微服务架构,实现Serverless化的应用部署与运维模式。以下是对SAE产品使用合集的概述,包括应用管理、服务治理、开发运维、资源管理等方面。
|
3月前
|
IDE Java Linux
在Maven中设置JVM系统参数及Java应用调试实例
在Maven中设置JVM系统参数及Java应用调试实例
122 0
|
3月前
|
JSON 监控 Java
编写电脑监控软件的Groovy脚本:JVM生态系统的整合与扩展
使用Groovy编写脚本监控Java虚拟机(JVM)的健康状况,包括内存使用和CPU利用率。脚本可自动将数据提交至指定网站,确保及时发现系统问题,防止服务中断。通过结合Runtime和OperatingSystemMXBean类获取系统信息,利用Groovy的HTTP客户端库POST数据到监控网站,实现高效稳定的系统监控。
116 0
|
4月前
|
人工智能 运维 Java
Serverless 应用引擎产品使用之在阿里云函数计算中设置JVM参数如何解决
阿里云Serverless 应用引擎(SAE)提供了完整的微服务应用生命周期管理能力,包括应用部署、服务治理、开发运维、资源管理等功能,并通过扩展功能支持多环境管理、API Gateway、事件驱动等高级应用场景,帮助企业快速构建、部署、运维和扩展微服务架构,实现Serverless化的应用部署与运维模式。以下是对SAE产品使用合集的概述,包括应用管理、服务治理、开发运维、资源管理等方面。
|
4月前
|
Java Serverless 对象存储
Serverless 应用引擎常见问题之jvm在进行垃圾回收的时候会导致重启如何解决
Serverless 应用引擎(Serverless Application Engine, SAE)是一种完全托管的应用平台,它允许开发者无需管理服务器即可构建和部署应用。以下是Serverless 应用引擎使用过程中的一些常见问题及其答案的汇总:
|
4月前
|
Cloud Native Java Docker
【Spring云原生】Spring官宣,干掉原生JVM,推出 Spring Native!整体提升性能!Native镜像技术在Spring中的应用
【Spring云原生】Spring官宣,干掉原生JVM,推出 Spring Native!整体提升性能!Native镜像技术在Spring中的应用