所谓回调,就是在执行某个程序时,具体的封装处理由第三方类来实现,简单一点说就是记录内部,再出来(由第三方类可以对数据进行处理),再返回去继续执行,这个过程就是回调。想要程序具有记录内部的功能就必须定义一个规范,也就是接口,即你的程序出来被其他类处理了,但你规定了还要返回原程序。
下面看一个简单的例子:
/**
* @描述:回调函数--记录内部,再出来返回去的过程就叫回调
* @author cxie
*/
public class CopyOfCallBackDemo {
public static void main(String[] args) {
QRunner run = new QRunner();
run.query("张三",new RunnerHandler1(){
@Override
public void handler(String name) {
System.err.println(name+"1");
}
});
}
}
/**
* 定义调用类
*/
class QRunner{
public void query(String sql,RunnerHandler1 rh){
//调用规范的实现类
System.err.println(sql+"o");
rh.handler(sql);
}
}
/**
* 定义回调规范
*/
interface RunnerHandler1{
void handler(String name);
}
程序的执行结果如下
下面再看一个高级一点的例子,通过定义泛型,使回调具有任意的返回值
<span style="font-size:18px;">package hd.cx.dbutilTest;
import java.util.List;
import java.util.Map;
/**
* @描述:回调函数--记录内部,再出来返回去的过程就叫回调
* @author cxie
* @拓展:通过定义泛型,使回调具有任意的返回值
*
*/
public class CallBackDemo {
public static void main(String[] args) {
Runner run = new Runner();
run.query("zhangsan",new RunnerHandler<List<Map<String, Object>>>()/** 定义了该方法的规范*/{
@Override
public List<Map<String,Object>> handler(String name){
System.err.print(name+"1");
return null;
}
});
}
}
/**
* 定义一个调用类
*/
class Runner{
public <T>/**这里是定义泛型*/ T query(String sql,RunnerHandler<T>/**这里是使用泛型*/ rh){
//调用一规范的实现类
System.err.println(sql+"0");
return rh.handler(sql);
}
}
/**
* 定义一个回调规范:接口
*/
interface RunnerHandler<T>{
T handler(String name);
}</span>
程序的运行结果同样如下
由此可以看出程序先执行调用类再回调回去执行接口定义的方法。
接下来是简单模拟Queryrunner中的两种方法来来编写自己的Queryrunner(一种是封装成Map放到List中,一种是封装到JavaBean中,暂时先不使用回调函数,大概了解一下原理)
<span style="font-size:18px;">import java.lang.reflect.Method;
import java.sql.Connection;
import java.sql.ResultSet;
import java.sql.ResultSetMetaData;
import java.sql.SQLException;
import java.util.ArrayList;
import java.util.HashMap;
import java.util.List;
import java.util.Map;
import javax.sql.DataSource;
import java.sql.Statement;
/**
* @描述:模拟queryrunner编写一个封装数据库操作的方法
* @author cxie
*
*/
public class QueryRunner {
private DataSource ds;
public QueryRunner(){
}
public QueryRunner(DataSource ds){
this.ds=ds;
}
/**
* 只封装List<Map>
*/
public List<Map<String,Object>> query(String sql){
//封装数据用
List<Map&l