一尘不染

Java中的委托与回调

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);
    }
}

那又如何实现呢?


阅读 346

收藏
2020-12-03

共1个答案

一尘不染

这是一个回调。根据维基百科

在计算机编程中,回调是对一段可执行代码的引用,该可执行代码作为参数传递给其他代码。

因此,让我们看一下可执行代码:

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
        }
    }
2020-12-03