使用apache的开源工具dbutils时, 我们可以用QueryRunner很方便地进行数据库查询操作,将查到的数据封装到JavaBean对象中, 或是封装到存储多个JavaBean对象的集合框架中. 其中用到的一个重要接口是ResultHandler, 该接口是如何实现对JavaBean对象的封装的呢? 其原理其实是利用回调函数来完成的.
下面通过一个小例子展示一下如何使用回调函数.
1. 首先定义接口(该接口使用了泛型):
/**
* 定义回调规范
*/
interface IHandler<T>{
T sayHi(String sql);
}
2. 再定义调用类, 其query方法接收一个实现了IHandler接口的对象, 在query方法体内调用IHandler的sayHi方法:
/**
* 定义调用类
*/
class MyRunner {
public <T>T query(String sql,IHandler<T> h){
return h.sayHi(sql);
}
}
3, 测试如何使用回调函数:
public class CallBackMethodDemo {
/**
* 回调函数例子
*/
public static void main(String[] args) {
MyRunner run = new MyRunner();
List<Map<String, Object>> list = run.query("yueyayun...",new IHandler<List<Map<String,Object>>>(){
@Override
public List<Map<String, Object>> sayHi(String sql) {
Map<String,Object> map = new HashMap<String, Object>();
map.put(sql, map);
List<Map<String,Object>> ll = new LinkedList<Map<String,Object>>();
ll.add(map);
ll.add(new HashMap<String, Object>());
return ll;
}
});
System.out.println(list);
}
}
从以上代码可以看到, 我们可以写多个实现了IHandler接口的具体类来完成各种的丰富功能, 在调用run.query方法时指定一个完成某项功能的IHandler接口实现类, 达到完成类似ResultHandler的效果.
建议有兴趣的同学看看apache的dbutils工具的源码, 它将有助于你深刻理解回调函数.