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

Groovy初体验:构建高性能JVM应用,第1张

概述为什么要学Groovy Groovy运行于JVM之上,然而其对动态语言、函数式编程范式以及元编程功能的加持所带来的表现力和简洁性可以说甩了Java几条街。我们可以利用Groovy的所有动态功能构建高性能的JVM应用、将开发效率提高几个数量级! 这就是我们为什么要学它! 注: 本文首发于 My 公众号 CodeSheep ,可 长按 或 扫描 下面的 小心心 来订阅 ↓ ↓ ↓ Groovy环境部署

为什么要学Groovy

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

注: 本文首发于 My 公众号 CodeSheep ,可 长按 或 扫描 下面的 小心心 来订阅 ↓ ↓ ↓

Groovy环境部署

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

@H_502_47@首先在命令行下执行:

curl -s get.sdkman.io | bash

@H_502_47@接下来执行:

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

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

一句话搞定!

sdk install groovy

@H_502_47@完成之后我们来检查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 HelloHello World From Groovy !
Groovy语言特性 @H_502_47@Groovy是轻量级的Java @H_502_47@Groovy的信噪比比Java高:较少的代码获得更多结果 @H_502_47@GDK = Groovy JDK:通过向JDK的各种类中添加便捷方法,Groovy扩展了JDK形成了GDK库 @H_502_47@return语句可选,分号结尾可选 @H_502_47@方法和类默认public @H_502_47@导航 *** 作符可帮助实现对象引用不为空时方法才会被调用 @H_502_47@Groovy不强迫捕获自己不关心的异常,没捕获的异常自动传到高层 @H_502_47@静态方法内可使用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',{...})
后记 @H_502_47@作者更多的原创文章在此,欢迎观赏 @H_502_47@My Personal Blog

作者更多的SpringBt实践文章在此:

@H_502_47@Spring Boot应用监控实战 @H_502_47@SpringBoot应用部署于外置Tomcat容器 @H_502_47@ElasticSearch搜索引擎在SpringBt中的实践 @H_502_47@初探Kotlin+SpringBoot联合编程 @H_502_47@Spring Boot日志框架实践 @H_502_47@SpringBoot优雅编码之:Lombok加持

如果有兴趣,也可以抽点时间看看作者一些关于容器化、微服务化方面的文章:

@H_502_47@利用K8S技术栈打造个人私有云 连载文章 @H_502_47@从一份配置清单详解Nginx服务器配置 @H_502_47@Docker容器可视化监控中心搭建 @H_502_47@利用ELK搭建Docker容器化应用日志中心 @H_502_47@RPC框架实践之:Apache Thrift @H_502_47@RPC框架实践之:Google gRPC @H_502_47@微服务调用链追踪中心搭建 @H_502_47@Docker容器跨主机通信 @H_502_47@Docker Swarm集群初探 @H_502_47@高效编写Dockerfile的几条准则

总结

以上是内存溢出为你收集整理的Groovy初体验:构建高性能JVM应用全部内容,希望文章能够帮你解决Groovy初体验:构建高性能JVM应用所遇到的程序开发问题。

如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。

欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/langs/1249452.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2022-06-07
下一篇 2022-06-07

发表评论

登录后才能评论

评论列表(0条)

保存