百度百科:
回调函数就是一个通过函数指针调用的函数。如果你把函数的指针(地址)作为参数传递给另一个函数,当这个指针被用来调用其所指向的函数时,我们就说这是回调函数。
在java中,没有函数指针的说法,那么,我们可以理解成,类A接受诸如类B1、类B2传递过来的对象,从而在类A中完成对类B1、类B2的调用。
java中是通过Interface来实现回调的。
这么说有点拗口,下面看例子。
Caller类:
public class Caller {
private Callback callback;
public Caller(){
}
public void setCallback(Callback cb){
this.callback = cb;
}
public void call(){
callback.doSomething();
}
}
Callback类:
interface Callback {
public void doSomething();
}
public class MyCallback1 implements Callback{
@Override
public void doSomething() {
// TODO Auto-generated method stub
System.out.println("I can do anything here in MyCallback1");
}
}
MyCallback2类:
public class MyCallback2 implements Callback{
@Override
public void doSomething() {
// TODO Auto-generated method stub
System.out.println("I can do anything here in MyCallback2");
}
}
最后,在Test类中完成测试:
public class Test {
public static void main(String[] args) {
Caller caller = new Caller();
MyCallback1 myCallback1 = new MyCallback1();
MyCallback2 myCallback2 = new MyCallback2();
//将myCallback1设置进caller中
caller.setCallback(myCallback1);
caller.call();
//将myCallback2设置进caller中
caller.setCallback(myCallback2);
caller.call();
}
}
运行结果:
I can do anything here in MyCallback1
I can do anything here in MyCallback2
下面我们来画类图,就会很清晰了:
如图所示:
Caller接受的是接口Callback的实例,在Caller的call()方法中实现了调用Callback类的doSomething()函数。
为了有很好的扩展性,我们必须把Callback设成接口类型。
这样我们可以有MyCallback1、MyCallback2、MyCallback3....来实现不同的doSomething()方法。
这样,在Test类中,只要往Caller中传递不一样的Callback实现类,就可以实现不同的doSomething()内容。
至此,回调方法介绍完毕。
作者能力有限,分享有错的地方烦请指出,谢谢。