Groovy(一)-注释,关键词,标识符

译文:Groovy Language Documentation

 这一个文集主要是为了翻译Groovy语言的文档的,因为我们知道Gradle是基于groovy语言的,所以我们有必要来学习这个语言,我们会把文档一步一步来翻译,如果大家有兴趣或者有发现错误都可以指出。

介绍

Groovy...

  • 是一种基于java虚拟机,灵活,动态的语言。
  • 集成了java的强大之处,且同时拥有例如Python,Ruby,Smalltalk的一些强大特征。
  • 对于java开发者可以零学习曲线地使用到现代编程特性。
  • 针对健壮性和性能提供了静态类型检查和静态编译代码。
  • 支持领域特定语言和其他精简的语法来使你的代码更易读和易维护。
  • 强大的原生类型处理,面向对象特性,Ant DSL,使你的shell编写和编译脚本更精简。
  • 当开发web, GUI, 数据库或者控制台代码时通过减少一些框架性的代码来提高开发效率。
  • 支持unit 测试和模拟开箱即用的思想来简化测试。
  • 和现有的java类和库无缝集成。
  • 直接编译成java字节码所以你可以在任何能使用java的地方使用它。

1.Groovy语言规范

1.1.语法

这个章节涵盖了Groovy编程语言的语法。它的语法由java语法产生,并且增加了一些特定的结构,特定的简写。

1.1.1.注释

单行注释
单行注释以//开头,并且能在行的任何位置。从//开始,到一行结束,都被认为是注释的部分。

// a standalone single line comment
println "hello" // a comment till the end of the line

多行注释
多行注释以/*开头,并且能在行的任何位置 。以/*开头,包括新的行,直到第一个*/结束都被认为是注释的部分。多行注释可以放于声明的开始或者声明的中间。

/* a standalone multiline comment
   spanning two lines */
println "hello" /* a multiline comment starting
                   at the end of a statement */
println 1 /* one */ + 2 /* two */

GroovyDoc 注释
和多行注释类似,GroovyDoc 注释也是多行的,但是它是以/**开始以*/结束。在第一个GroovyDoc 注释行之后的新行可以选择添加*或者不添加,这不是强制的。这些注释跟下面这些相关:

  • 类型定义(类,接口,枚举,注解)
  • 字段和属性的定义
  • 方法的定义

虽然编译期并不关心GroovyDoc 注释跟上面的语言元素相关,但是你自己要保持正确的注释习惯。

/**
 * A Class description
 */
class Person {
    /** the name of the person */
    String name

    /**
     * Creates a greeting method for a certain person.
     *
     * @param otherPerson the person to greet
     * @return a greeting message
     */
    String greet(String otherPerson) {
       "Hello ${otherPerson}"
    }
}

GroovyDoc(Groovy文档)遵循跟javaDoc一样的约定,所以你能使用跟javaDoc一样的标签。
Shebang(#!) 行
除了单行注释,还有一种特殊的行注释,它就是shebang行。如果你已经安装了Groovy的发布版并且把groovy命令已经配置到PATH的话,那么UNIX 系统会直接通过命令行来运行脚本。

#!/usr/bin/env groovy
println "Hello from the shebang line"

注意:字符#必须是文件的首字符,如果缩进的话也会报错。

1.1.2.关键字

下面表列出了所有Groovy语言中的关键字。


关键字表
1.1.3.标识符

普通标识符
标识符可以以字符,$,或者下划线开头,但是不能以数字开头。
一个字符能在下面这些范围:

  • 'a' to 'z' (ascii 表的小写字符)
  • 'A' to 'Z' (ascii 表的大写字符)
  • '\u00C0' to '\u00D6'
  • '\u00D8' to '\u00F6'
  • '\u00F8' to '\u00FF'
  • '\u0100' to '\uFFFE'

下面这些字符能包括特定的字母和数字。
这里有一些正确标识符的例子:

def name
def item3
def with_underscore
def $dollarStart

但是下面这些是非法的标识符:

def 3tier
def a+b
def a#b

所有的关键字跟上.号也是正确的标识符。
引用标识符
引用标识符是以.开始的。例如person.name中的name部分可以用person."name"person.'name'来引用。有趣的是一些特定标识符包含合法的字符在java语言规范中是禁止的,但是在Groovy规范的引用中是允许的。比如破折号,空格,感叹号等:

def map = [:]

map."an identifier with a space and double quotes" = "ALLOWED"
map.'with-dash-signs-and-single-quotes' = "ALLOWED"

assert map."an identifier with a space and double quotes" == "ALLOWED"
assert map.'with-dash-signs-and-single-quotes' == "ALLOWED"

正如我们下面在 following section on strings会看到的,Groovy 提供了不同的字符常量,这些字符常量都允许在.后面。

map.'single quote'
map."double quote"
map.'''triple single quote'''
map."""triple double quote"""
map./slashy string/
map.$/dollar slashy string/$

纯字符的字符串和Groovy的GStrings (嵌套字符串)不同的是,后面这种情况,嵌套字符串在整个字符标识符的后面插入:

def firstname = "Homer"
map."Simpson-${firstname}" = "Homer Simpson"

assert map.'Simpson-Homer' == "Homer Simpson"
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 201,924评论 5 474
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 84,781评论 2 378
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 148,813评论 0 335
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,264评论 1 272
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,273评论 5 363
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,383评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 37,800评论 3 393
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,482评论 0 256
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,673评论 1 295
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,497评论 2 318
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,545评论 1 329
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,240评论 4 318
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,802评论 3 304
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,866评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,101评论 1 258
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 42,673评论 2 348
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,245评论 2 341

推荐阅读更多精彩内容

  • Spring Cloud为开发人员提供了快速构建分布式系统中一些常见模式的工具(例如配置管理,服务发现,断路器,智...
    卡卡罗2017阅读 134,573评论 18 139
  • Groovy是一门基于JVM的动态语言,很多语法和Java类似。大部分Java代码也同时是合法的Groovy代码。...
    乐百川阅读 3,571评论 0 15
  • 前言 人生苦多,快来 Kotlin ,快速学习Kotlin! 什么是Kotlin? Kotlin 是种静态类型编程...
    任半生嚣狂阅读 26,133评论 9 118
  • 11.14一个平常的周二,下午正在抽空绘制之前的思维导图任务,办公室专做以色列线路的同事突然说:小陆,小贾来了。抬...
    陆娴1983阅读 286评论 0 1
  • 很喜欢尝试新的有趣App,在这个过程中也了解了一些常用的渠道和相关的网站,在此做个发掘iOS应用渠道的总结。 欢迎...
    93c9803df6de阅读 2,546评论 0 6