Demo : 这里我们定义一个接口A,然后接口或类中创建一个方法run,创建B类实现接口A,并且重写run方法,最后创建C类,定义transfer()方法形参列表传入一个接口引用(后面通过多态传入实现类B对象或者匿名内部类),并在transfer()方法里面调用接口中的run()方法,当在B中调用创建C对象调用transfer()方法并且传入B的一个实例时,发现自己重写的方法也被调用了,但是我们并没有在B中调用run()方法啊,这就是回调,实际上我们在C类中已经通过接口引用调用了run()方法,通过多态B实例替换了接口引用,然后就自动调用了run()方法,给我们造成了一种假象(我没有调用这个方法啊,它怎么执行了)。 下面以一个简单的实例展示一下: 代码示例:
接口A:
//定义接口A public interface A{ // 定义抽象方法 public void run(); }B类::
//定义B类实现接口 public class B implements A { //重写接口run()方法 @Override public void run() { System.out.println("run方法被调用"); } public static void main(String []args){ //创建B对象 B b=new B(); //通创建C对象调用transfer()方法 new C.transfer(b); } }C类:
//定义C类 public class C{ //定义transfer()方法传参调用run()方法 public void transfer(A a){ a.run(); } }运行结果:
