在计算机编程中,回调是对一段可执行代码的引用,该可执行代码作为参数传递给其他代码。
因此,让我们看一下可执行代码:
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();
}
}
…那将是委派。
还要注意的是// 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
}
}