groovy语法
变量
Groovy中用def关键字来定义变量,可以不指定变量的类型,默认访问修饰符是public。
def a = 1;
def intb = 1;
def c = “hello world”;
方法
可用def关键字定义方法(代表方法的返回类型方法,可以接收任意数量的参数,这些参数可以不申明类型,如果不提供可见性修饰符,则该方法为public。
def add(inta,intb){ println a+b //3}
-
如果指定了方法返回类型,可以不需要def关键字来定义方法。
int minus(a,b){ return a-b }
-
如果不使用return ,方法的返回值为最后一行代码的执行结果。
` int minus(a,b){ a-b //4} ’ -
从上面两段代码中可以发现Groovy中有很多省略的地方:语句后面的分号可以省略。方法的括号可以省略,比如注释1和注释3处。参数类型可以省略。return可以省略掉.
-
Groovy类与Java类有以下的区别:
- 默认类的修饰符为public。
- 没有可见性修饰符的字段会自动生成对应的setter和getter方法。
-def x = 0 for( i in 0.. 3) { x += i } assertx == 6
- 在Groovy种有两种字符串类型,普通字符串String(java.lang.String)和插值字符串Gstring
- 双引号中可使用插值
def name = 'Android进阶之光' println "hello ${name}" println "hello $name"
- .3
Map创建Map同样使用[],需要同时指定键和值,默认的实现类为java.util.LinkedHashMap。
def name = [one: ‘魏无羡’, two: ‘杨影枫’, three: ‘张无忌’]
assertname[ ‘one’] == '魏无羡’assertname.two == ‘杨影枫’
Map还有一个键关联的问题:def key = 'name’def person = [key: ‘魏无羡’] /assert person.containsKey( ‘key’) person = [(key): ‘魏无羡’]
//2 assertperson.containsKey( ‘name’)
注释1处魏无羡的键值是key这个字符串,而不是key变量的值 name。如果想要以key变量的值为键值,需要像注释2处一样使用(key),用来告诉解析器我们传递的是一个变量,而不是定义一个字符串键值。
7.4 闭包(Closure)Groovy中的闭包是一个开放的、匿名的、可以接受参数和返回值的代码块。
Groovy的文件读取是很简洁的,还可以更简洁些:
def filePath = "D:/Android/name.txt"def file = newFile(filePath) ; println file.text 8.2 文件写入文件写入同样十分简洁:
def filePath = "D:/Android/name.txt"def file = newFile(filePath); file.withPrintWriter { it.println( “三井寿”) it.println( “仙道彰”) }
9. 其他9.1 asTypeasType可以用于数据类型转换:String a = '23’intb = a as intdef c = a.asType(Integer) assertc instanceofjava.lang.Integer 9.2 判断是否为真if( name!= null && name.length > 0) {}可以替换为if( name) {}9.3 安全取值在
参考:https://www.sohu.com/a/258544633_100004247
import com.intellij.database.model.DasTable
import com.intellij.database.util.Case
import com.intellij.database.util.DasUtil
/*
* Available context bindings:
* SELECTION Iterable<DasObject>
* PROJECT project
* FILES files helper
*/
//改包名
packageName = "com.lmj.entity;"
typeMapping = [
(~/(?i)int/) : "long",
(~/(?i)float|double|decimal|real/): "double",
(~/(?i)datetime|timestamp/) : "java.sql.Timestamp",
(~/(?i)date/) : "java.sql.Date",
(~/(?i)time/) : "java.sql.Time",
(~/(?i)/) : "String"
]
//选择要存储的文件目录
FILES.chooseDirectoryAndSave("Choose directory", "Choose where to store generated files") { dir ->
SELECTION.filter { it instanceof DasTable }.each { generate(it, dir) }
}
def generate(table, dir) {
def className = javaName(table.getName(), true)
def fields = calcFields(table)
new File(dir, className + ".java").withPrintWriter { out -> generate(out, className, fields) }
}
def generate(out, className, fields) {
out.println "package $packageName"
out.println ""
out.println ""
out.println "public class $className {"
out.println ""
fields.each() {
if (it.annos != "") out.println " ${it.annos}"
out.println " private ${it.type} ${it.name};"
}
out.println ""
fields.each() {
out.println ""
out.println " public ${it.type} get${it.name.capitalize()}() {"
out.println " return ${it.name};"
out.println " }"
out.println ""
out.println " public void set${it.name.capitalize()}(${it.type} ${it.name}) {"
out.println " this.${it.name} = ${it.name};"
out.println " }"
out.println ""
}
out.println "}"
}
def calcFields(table) {
DasUtil.getColumns(table).reduce([]) { fields, col ->
def spec = Case.LOWER.apply(col.getDataType().getSpecification())
def typeStr = typeMapping.find { p, t -> p.matcher(spec).find() }.value
fields += [[
name : javaName(col.getName(), false),
type : typeStr,
annos: ""]]
}
}
def javaName(str, capitalize) {
def s = com.intellij.psi.codeStyle.NameUtil.splitNameIntoWords(str)
.collect { Case.LOWER.apply(it).capitalize() }
.join("")
.replaceAll(/[^\p{javaJavaIdentifierPart}[_]]/, "_")
capitalize || s.length() == 1? s : Case.LOWER.apply(s[0]) + s[1..-1]
}
参考文章
写的非常详细:https://blog.youkuaiyun.com/zhaoyanjun6/article/details/70313790