Java中的委托与回调
我对Java中的委托和回调的术语有些误解。
class MyDriver { public static void main(String[] argv){
MyObject myObj = new MyObject();
// definition of HelpCallback omitted for brevity
myObj.getHelp(new HelpCallback () {
@Override
public void call(int result) {
System.out.println("Help Callback: "+result);
}
});
}
}
class MyObject {
public void getHelp(HelpCallback callback){
//do something
callback.call(OK);
}
}
那又如何实现呢?
回答:
这是一个回调。根据维基百科:
在计算机编程中,回调是对一段可执行代码的引用,该可执行代码作为参数传递给其他代码。
因此,让我们看一下可执行代码:
public void getHelp(HelpCallback callback){ //do something
callback.call(OK);
}
在这里,callback
参数是对type对象的引用HelpCallback
。由于该引用作为参数传递,因此它是一个回调。
委托示例
委托由对象内部完成-与方法的调用方式无关。例如,如果callback
变量不是参数,而是实例变量:
class MyDriver { public static void main(String[] argv){
// definition of HelpStrategy omitted for brevity
MyObject myObj = new MyObject(new HelpStrategy() {
@Override
public void getHelp() {
System.out.println("Getting help!");
}
});
myObj.getHelp();
}
}
class MyObject {
private final HelpStrategy helpStrategy;
public MyObject(HelpStrategy helpStrategy) {
this.helpStrategy = helpStrategy;
}
public void getHelp(){
helpStrategy.getHelp();
}
}
…那将是委派。
在这里,MyObject
使用策略模式。有两件事要注意:
- 的调用
getHelp()
不涉及传递对可执行代码的引用。即这不是回调。 - 从对象的公共接口或
MyObject.getHelp()
调用中看helpStrategy.getHelp()
不到调用的事实。这种信息隐藏是委派的特征。MyObject``getHelp()
还要注意的是// do
something,该getHelp()
方法中缺少一个部分。使用回调时,回调不会执行与对象行为相关的任何操作:它只是以某种方式通知调用者,这就是为什么//
do something必须要有一个节的原因。但是,当使用委托时,该方法的实际行为取决于委托-因此,由于它们有不同的用途,因此我们最终可能同时需要两者:
public void getHelp(HelpCallback callback){ helpStrategy.getHelp(); // perform logic / behavior; "do something" as some might say
if(callback != null) {
callback.call(); // invoke the callback, to notify the caller of something
}
}
以上是 Java中的委托与回调 的全部内容, 来源链接: utcz.com/qa/398502.html