接口回调解析


为什么会有接口回调?什么是接口回调?

其实这两个问题是一个问题,知道了接口回调的原理自然就知道了为什么会有这么个东西。我们知道java中接口是不可以直接创建实例的,那么问题来了,假如我把一个接口声明为一个变量,那么我执行这个接口中的方法,接口没有实例它该怎么办呢?啊哈,这里自然又改出现java中的另一个特性—“多态”,这时java虚拟机自然会去找其子类,调用其子类中已经重载的该方法,这里就是接口回调的本质!!
我们在网络请求等耗时的操作的时候会使用到该机制,用来把得到的数据传回主线程中。

应用场景:

比如我写一个工具,下载任务,下载任务可能成功,可能失败。为了解耦,我的这个下载工具类只能专门用来下载,如何处理成功和失败,这个就交给调用方来完成。

回调接口的接口声明:

/**
 * @描述: 结果回调
 */
public interface ResultCallback {

    void success();

    void failure(Exception e);
}

下载工具类,定义回调接口变量,并在代码中调用接口的方法

/**
 * @描述: 下载任务
 */
public class Download {

    private ResultCallback callback;

    public Download(ResultCallback callback) {
        this.callback = callback;
    }

    public void excuteDownload(String usrl) {

        new Thread(new Runnable() {
            @Override
            public void run() {
                HttpURLConnection conn = null;
                try {
                    conn = (HttpURLConnection) new URL(usrl).openConnection();
                    conn.setConnectTimeout(5 * 1000);
                    conn.setRequestMethod("GET");
                    //做些什么

                    callback.success();  //thing's done callback
                } catch (IOException e) {
                    callback.failure(e);   // thing's error  callback
                }
            }
        });
    }
}

调用方:创建下载类对象,因为下载类的构造函数里有回调接口类,不能实例化,所以你需要实现该接口

public static void main(String args[]){

      new Download(new ResultCallback() {
          @Override
          public void success() {
              //下载完后做一些事
          }

          @Override
          public void failure(Exception e) {
              //do something when work is fail
          }
      }).excuteDownload("your parameter");
  }

总结

接口回调,实际上是利用了java中的多态性,利用父亲引用指向子类的地址,从而实现父亲接口调用子类实现类的方法。接口回调是设计模式的解耦核心,可以说几乎所有的模式都用到了接口回调。


文章作者: greatsawyer
版权声明: 本博客所有文章除特別声明外,均采用 CC BY 4.0 许可协议。转载请注明来源 greatsawyer !
  目录