使用回调函数,简单模拟dbutils中Queryrunner的工作原理,并重写Queryrunner,使其使用起来更加简单方便

本文介绍了回调函数的概念,通过实例展示了如何使用回调实现程序的内部处理。接着模拟dbutils的Queryrunner,分别演示了将结果封装到Map列表和JavaBean中的实现。同时,通过自定义BeanListHandler回调函数,简化了异常处理,避免了在调用时每次都需try-catch。最后,展示了如何继承并重写dbutils的Queryrunner以捕获异常,提高代码简洁性。
摘要由CSDN通过智能技术生成

所谓回调,就是在执行某个程序时,具体的封装处理由第三方类来实现,简单一点说就是记录内部,再出来(由第三方类可以对数据进行处理),再返回去继续执行,这个过程就是回调。想要程序具有记录内部的功能就必须定义一个规范,也就是接口,即你的程序出来被其他类处理了,但你规定了还要返回原程序。

下面看一个简单的例子:

/**
 * @描述:回调函数--记录内部,再出来返回去的过程就叫回调
 * @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
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值