为什么会有接口回调?什么是接口回调?
其实这两个问题是一个问题,知道了接口回调的原理自然就知道了为什么会有这么个东西。我们知道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");
//do download things here ...
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() {
//do something when work is done
}
@Override
public void failure(Exception e) {
//do something when work is fail
}
}).excuteDownload("your parameter");
}
总结
接口回调,实际上是利用了java中的多态性,利用父亲引用指向子类的地址,从而实现父亲接口调用子类实现类的方法。接口回调是设计模式的解耦核心,可以说几乎所有的模式都用到了接口回调。