我对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
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使用策略模式。有两件事要注意:
MyObject
getHelp()
MyObject.getHelp()
helpStrategy.getHelp()
MyObject``getHelp()
还要注意的是// do something,该getHelp()方法中缺少一个部分。使用回调时,回调不会执行与对象行为相关的任何操作:它只是以某种方式通知调用者,这就是为什么// do something必须要有一个节的原因。但是,当使用委托时,该方法的实际行为取决于委托-因此,由于它们有不同的用途,因此我们最终可能同时需要两者:
// 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 } }