这是一个回调。根据维基百科 http://en.wikipedia.org/wiki/Callback_%28computer_programming%29:
在计算机编程中,回调是对一段可执行代码的引用,该代码作为参数传递给其他代码。
那么我们来看看可执行代码:
public void getHelp(HelpCallback callback){
//do something
callback.call(OK);
}
在这里,callback
参数是对类型对象的引用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();
}
}
...那么这将是授权。
Here, MyObject
使用策略模式 http://en.wikipedia.org/wiki/Strategy_pattern。有两点需要注意:
- 的调用
getHelp()
不涉及传递对可执行代码的引用。即这不是回调。
- 事实是
MyObject.getHelp()
调用helpStrategy.getHelp()
从公共界面来看并不明显MyObject
对象或来自getHelp()
调用。这种信息隐藏 http://en.wikipedia.org/wiki/Information_hiding有点委托的特征。
还值得注意的是缺乏// 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
}
}