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使用策略模式。有两件事要注意:

  1. 的调用getHelp()不涉及传递对可执行代码的引用。即这不是回调。
  2. 从对象的公共接口或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

回到顶部