概述
Groovy Tip 13 “.&”运算符
在Groovy语言中,“
.&”运算符是用来引用一个方法,请看下面的例子:
class
Foo
{
def
hello(name)
{
println
"hello,${name}!"
}
}
通常,我们是这样来使用
Foo
类的
hello
方法:
Foo foo =
new
Foo()
foo.hello(
'world'
)
现在,我们在
Groovy
语言里也可以这样使用:
Foo foo =
new
Foo()
def
hello = foo.&hello
hello(
'Tom'
)
语句“
def
hello = foo.&hello
”的意思是定义一个“
hello
”对象,并且将它指向“
foo
”对象的“
hello
”方法。然后,我们就可以直接使用刚刚定义的“
hello
”对象。上面的代码的结果为:
hello,Tom!
静态方法也可以使用“
.&”运算符来引用,如下:
class
Foo
{
def
static
f()
{
println
'oh,...'
}
}
可以这样来使用:
def
f = Foo.&f
f()
结果为:
oh,...
简单的介绍到此为止,下面来说说如何在实际的代码中使用它。在实际的编码过程中,记录
log
是免不了的了。如下:
if
(
logger
.isDebugEnabled()){
logger
.debug(
"updateNullCRTarget condition:"
);
logger
.debug(
"year="
+ year);
logger
.debug(
"type="
+ mytype);
logger
.debug(
"buyer="
+ buyer);
}
如果你写“
logger.debug
”写烦了,不如这样实现:
def
debug = logger.&debug
if
(logger.isDebugEnabled()){
debug(
"updateNullCRTarget condition:"
);
debug(
"year="
+ year);
debug(
"type="
+ mytype);
debug(
"buyer="
+ buyer);
}
如果上面的样子看着不舒服,也可以这样实现:
def
debug = logger.&debug
if
(logger.isDebugEnabled()){
debug
"updateNullCRTarget condition:"
debug
"year=$year"
debug
"type=$mytype"
debug
"buyer=$buyer"
}
实际的编码过程中可能有很多这样的例子,你会在一段代码中不断的调用另外一个类的方法,如果你讨厌不停的写“对象名
.
方法名”或者“类名
.
方法名”,那么你就可以使用上面的方法。
“
.&”运算符的第二个用途是委派功能。我们知道,我们如果想要在一个类中使用另一个类的功能,最直接的方法是继承。但我们在很多时候都指出,过多使用继承会导致很多的副作用。在Groovy语言中,我们常常使用委派来代替继承。
“
.&”运算符也能实现功能的委派,而且是动态委派的基础。下面,我们来看看它是如何实现委派的:
class
Foo
{
def
hello()
{
println
"hello,world!"
}
}
下面有一个
World
类:
class
World
{
}
可以看到,
World
类没有任何的方法,它现在想继承
Foo
类的
hello
方法。
Foo foo =
new
Foo()
World.metaClass.hello = foo.&hello
def
w =
new
World()
w.hello()
运行结果为:
hello,world!
“
.&”运算符
除了上面的用法,我们还需要记住的是,形如“
def
hello = foo.&hello
”的语句同时也声明了“
hello
”对象是一个闭包,闭包的任何用法都可以使用在“
hello
”对象上,如可以把它当对象一样传递,可以
curry
,可以复合等等。
最后
以上就是懦弱绿茶为你收集整理的Groovy Tip 13 “.&”运算符的全部内容,希望文章能够帮你解决Groovy Tip 13 “.&”运算符所遇到的程序开发问题。
如果觉得靠谱客网站的内容还不错,欢迎将靠谱客网站推荐给程序员好友。
本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
发表评论 取消回复