首先在网络上搜索很多文章介绍什么是回调函数,看的云里雾里的。后来自己一步步分解终于理解了,记录如下。
从维基百科上面摘抄定义:(看完本篇文章再来理解这个定义)
在计算机程序设计中,回调函数,或简称回调,是指通过函数参数传递到其它代码的,某一块可执行代码的引用。这一设计允许了底层代码调用在高层定义的子程序。
在Java里面,我们使用接口来实现回调。
这篇文章中的解说定义非常好:http://blog.csdn.net/sweetwxh/article/details/2067139
所谓的回调,就是程序员A写了一段程序(程序a),其中预留有回调函数接口,并封装好了该程序。程序员B要让a调用自己的程序b中的一个方法,于是,他通过a中的接口回调自己b中的方法。下面是例子。
1. 首先定义一个类Caller,按照上面的定义就是程序员A写的程序a,这个类里面保存一个接口引用。
public class Caller {
private MyCallInterface callInterface;
public Caller() {
}
public void setCallFunc(MyCallInterface callInterface) {
this.callInterface = callInterface;
}
public void call() {
callInterface.printName();
}
}
2. 当然需要接口的定义,为了方便程序员B根据我的定义编写程序实现接口。
public interface MyCallInterface {
public void printName();
}
3. 第三是定义程序员B写的程序b
public class Client implements MyCallInterface {
@Override
public void printName() {
System.out.println("This is the client printName method");
}
}
4. 测试如下
public class Test {
public static void main(String[] args) {
Caller caller = new Caller();
caller.setCallFunc(new Client());
caller.call();
}
}
看到这里应该明白什么是回调了,有些文章介绍的很好,但是刚开始没看明白,是因为把第3步的类省略,直接写成匿名类了。
5. 在测试方法中直接使用匿名类,省去第3步。
public class Test {
public static void main(String[] args) {
Caller caller = new Caller();
// caller.setCallFunc(new Client());
caller.setCallFunc(new MyCallInterface() {
public void printName() {
System.out.println("This is the client printName method");
}
});
caller.call();
}
}
看完了上面的文章,直接看下面这篇文章:
http://kidult.iteye.com/blog/148982
以上就是回调函数的全部理解。
转载:http://blog.csdn.net/allen_zhao_2012/article/details/8056665
自我理解:
观察者:事件A定义了一个方法b,监听者C也有一个方法d,该方法d通过事件A的引用,调用或重写了A的b方法。
这里面没有回调的意思。
回调:A中有方法b,而方法b中,通过C的引用,调用d的方法 。而C中d的方法,具体实现哪些内容,A中的方法b并不关心。在使用时,C要让A调用方法b,通过方法b来调自己的方法d,实现了回调。
观察者和回调,都可以通过内部类重写要实现的方法。