本文主要是介绍使用回调函数,简单模拟dbutils中Queryrunner的工作原理,并重写Queryrunner,使其使用起来更加简单方便,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!
所谓回调,就是在执行某个程序时,具体的封装处理由第三方类来实现,简单一点说就是记录内部,再出来(由第三方类可以对数据进行处理),再返回去继续执行,这个过程就是回调。想要程序具有记录内部的功能就必须定义一个规范,也就是接口,即你的程序出来被其他类处理了,但你规定了还要返回原程序。
下面看一个简单的例子:
/*** @描述:回调函数--记录内部,再出来返回去的过程就叫回调* @author cxie*/
public class CopyOfCallBackDemo {public static void main(String[] args) {QRunner run = new QRunner();run.query("张三",new RunnerHandler1(){@Overridepublic 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>>>()/** 定义了该方法的规范*/{@Overridepublic 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
这篇关于使用回调函数,简单模拟dbutils中Queryrunner的工作原理,并重写Queryrunner,使其使用起来更加简单方便的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!