重载运算符
//java code
String a="hello";
String b="world";
System.out.println(a==b); //prints false
System.out.println(a.equals); //prints true
Integer c=1,d=2;
System.out.println(c+d); //prints 3
//groovy code
def a="hello"
def b="world"
println a==b // prints true
def c=1,d=2
println c+d
- java中==是引用的比较,可类比C语言指针,equals才为值的比较
- java中Integer类型相加会自动拆装箱,即先转化成int 型相加再装箱成Integer对象
- groovy中==即equals
c+d即Integer相加,但groovy处理成c.plus(d),可类比C++
综上,groovy拥有java没有的重载运算符的高级特性,拥有C++重载运算符的优点
重载运算符的例子:
class Money{
int num;
Money(int num){
this.num = num;
}
boolean equals(Object money){
if(money == null||!(money instanceof Money)||money.num != num)
return false;
return true;
}
}
def money = new Money(100)
def money2 = new Money(100)
println money == money2 //prints true
String与GString
def string1 = '单引号'
def string2 = "双引号"
def string3 ='$string1 string'
def gstring = "$string1 gstring"
assert string1 instanceof String
assert string2 instanceof String
assert gstring instanceof GString
println gstring //prints 单引号 gstring
println string3 //prints $string1 string
~
- 单引号表示的字符串一定为String
- 双引号字符串当有占位符$时为GString,否则为String
- Java中String类型为final,可能此原因导致groovy创建了一个新的字符串类型GString
GString的使用
def a = 'sad'
def gstring = "$a cry" //(1) 占位符使用
def gstring2 = "${a.toString()} cry" //(2) 占位块使用
assert gstring.strings[0] == 'cry' //(3) 方法使用
assert gstrubg.values[0] == 'sad'
- (2) {} 即闭包
- (3) gstring分固定区和动态区,$即动态区
GString以$占位符的方式提供了一种字符串动态模板,有利于sql等语句的书写
修改字符串
def string = 'happy ending'
string = string << '!'
assert string instanceof java.lang.StringBuilder
println string.toString() //prints happy ending!
string[0..4] << 'sad'
println string.toString() //prints sad ending!
- groovy同java,java中String类型是不能修改的
- groovy使用<<插入语句返回了StringBuilder来进行字符串的修改
正则~/…/.isCase(‘表达式’) (难点)
regex查找操作符“=~”; 相当java中的matcher.find() 即部分匹配
regex匹配操作符“==~”; 相当java中的matcher.matcher() 即全部匹配
regex模式操作符:~String;相当于生成pattern类
- Matcher
def string =
'<span>写了39676字</span>,<span>被417人关注</span>,<span>获得了925个喜欢</span>'
matcher = string =~ "<span>(.*?)</span>" //=~生成Matcher类赋值给matcher
println matcher.count //prints 3
println matcher[0] //返回list,prints [<span>写了39676字</span>, 写了39676字]
println matcher[0][1] //取上述list第2个,prints 写了39676字
def numregex = /\d/
def notnumregex = /\D/
matcher1 = string =~ "$notnumregex($numregex+?)$notnumregex"
println matcher1.count
println matcher1[0][1]
说明:
1. / /为groovy特有书写字符串格式,为了避免转移符\\输两次的麻烦
2. () 为分组 matcher[0]返回的list第一项为regex全匹配项
3. 正则表达式规则不变
- Pattern
pattern = ~"$notnumregex($numregex+?)$notnumregex" //注意=~ 与 =~String区别
matcher2 = pattern.matcher(string)
println matcher2.count
assert pattern.isCase('a1a')
list = ['1s23','avc','222','sad']
println list
println list.grep(~"\\d*\\d")
switch('aaa')
{
case ~/.../ :
break;
}
说明:
1. pattern为有限状态机,故pattern在大规模相同模式匹配中速度比matcher快
2. list.grep基础在于pattern
3. groovy中switch语句基于pattern.isCase故可比较字符串,而java中只能是数字
数字的一些方法
1.upto(5){num->print num} //prints 12345
5.downto(闭包)
10.times{print '1' } //prints 1111111111