回调以及异步调用

来源出处:点击打开链接

例子1

首先看一段代码:

模板方式:

public abstract class B{  
     public void execute(){   
            getConnection();    
            doCRUD();    
            releaseConnection();    
        }    
  
      public abstract void doCRUD();  
  
      public void getConnection(){    
            System.out.println("获得连接...");    
        }    
            
        public void releaseConnection(){    
            System.out.println("释放连接...");    
        }    
}  
  
public class A extends B{  
    public void doCRUD(){    
          System.out.println("执行add操作...");    
     }    
  
     public void add(){    
             doCRUD();  
        }    
}  
  
public class C extends B{  
    public void doCRUD(){    
          System.out.println("执行delete操作...");    
     }    
  
     public void delete(){    
             doCRUD();  
        }
 }

改为回调模式:

public interface CallBack{     
    public void doCRUD();     
}
package huidiao.sample;

public class HibernateTemplate {     
    public void execute(CallBack action){    
        getConnection();    
        action.doCRUD();    
        releaseConnection();    
    }    
     
    public void add(){    
         execute(new CallBack(){    
            public void doCRUD(){    
                System.out.println("执行add操作...");    
            }    
         });    
     }     
  
     public void delete(){    
         execute(new CallBack(){    
            public void doCRUD(){    
                System.out.println("执行delete操作...");    
            }    
         });    
     }   
    
    public void getConnection(){    
        System.out.println("获得连接...");    
    }    
        
    public void releaseConnection(){    
        System.out.println("释放连接...");    
    }    
        
} 
可见 摒弃了继承抽象类方式的回调方式更加简便灵活 。不需要为了实现抽象方法而总是继承抽象类,而是只需要通过回调来增加一个方法即可,更加的直观简洁灵活。这算是回调的好处之一。 

下面再给出一个关于 利用回调配合异步调用 的很不错的例子,
例子2

回调接口: 

public interface CallBack {    
    /**  
     * 执行回调方法  
     * @param objects   将处理后的结果作为参数返回给回调方法  
     */    
    public void execute(Object... objects );    
} 
消息的发送者:

/** 
 * 这个类相当于你自己 
 */  
public class Local implements CallBack,Runnable{    
     
    private Remote remote;    
        
    /**  
     * 发送出去的消息  
     */    
    private String message;    
        
    public Local(Remote remote, String message) {    
        super();    
        this.remote = remote;    
        this.message = message;    
    }    
    
    /**  
     * 发送消息  
     */    
    public void sendMessage()    
    {    
        /**当前线程的名称**/    
        System.out.println(Thread.currentThread().getName());    
        /**创建一个新的线程发送消息**/    
        Thread thread = new Thread(this);    
        thread.start();    
        /**当前线程继续执行**/    
        System.out.println("Message has been sent by Local~!");    
    }    
    
    /**  
     * 发送消息后的回调函数  
     */    
    public void execute(Object... objects ) {    
        /**打印返回的消息**/    
        System.out.println(objects[0]);    
        /**打印发送消息的线程名称**/    
        System.out.println(Thread.currentThread().getName());    
        /**中断发送消息的线程**/    
        Thread.interrupted();    
    }    
        
    public static void main(String[] args)    
    {    
        Local local = new Local(new Remote(),"Hello");    
            
        local.sendMessage();    
    }    
    
    public void run() {    
        remote.executeMessage(message, this);  //这相当于给同学打电话,打完电话之后,这个线程就可以去做其他事情了,只不过等到你的同学打回电话给你的时候你要做出响应  
            
    }    
}    
消息的接收者:

/** 
 * 这个类相当于你的同学 
 */  
public class Remote {    
    
    /**  
     * 处理消息  
     * @param msg   接收的消息  
     * @param callBack  回调函数处理类  
     */    
    public void executeMessage(String msg,CallBack callBack)    
    {    
        /**模拟远程类正在处理其他事情,可能需要花费许多时间**/    
        for(int i=0;i<1000000000;i++)    
        {    
                
        }    
        /**处理完其他事情,现在来处理消息**/    
        System.out.println(msg);    
        System.out.println("I hava executed the message by Local");    
        /**执行回调**/    
        callBack.execute(new String[]{"Nice to meet you~!"});  //这相当于同学执行完之后打电话给你  
    }    
        
}   


执行Local类的main方法。

 

注意Local类中红色背景的那行:

remote.executeMessage(message, this);

executeMessage方法需要接收一个message参数,表示发送出去的消息,而CallBack参数是他自己,也就是这里的this。表示发送消息后,由Local类自己来处理,调用自身的execute方法来处理消息结果。

如果这里不是用this,而是用其他的CallBack接口的实现类的话,那就不能称之为“回调”了,在OO的世界里,那就属于“委派”。也就是说,“回调”必须是消息的发送者来处理消息结果,否则不能称之为回调。这个概念必须明确。




  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值