想必大家都用过apache 的DbUtils吧,这个简单的对JDBC的封装小框架真的是非常非常的适合新手的学习呢。逻辑上也不是很复杂,难度刚刚好。 下面我就模仿它来实现一个字符串的处理小框架。


思路

我的思路是这样的,根据DbUtils中的实现方式,来进行模拟处理。

示例分析

@Test
    public void insert() throws Exception {

        Connection conn = ConnTools.getConnection();
        QueryRunner runner = new QueryRunner();
        for (int i = 0; i < 10; i++) {
            runner.update(conn, "insert into dbutil(name) values(?)", "Mark"+(1+i));
        }
        // 记得用完数据库的链接就要及时的关闭!
        DbUtils.close(conn);
        System.out.println("成功差入10条数据!");
    }

从这里可以看出DbUtils使用了一个QueryRunner来实现业务逻辑的处理。所以待会我们也要这样来实现。

QueryRunner内部解析

从上面的例子中我们也可以看出,真正起作用的是QueryRunner的回调方法。这种面向接口的使用方式值Java编程思想中最为经典的一种方式。我们应该多多使用。

根据ResultSetHandler接口,我们待会也会模拟一个这样的实现。

分层思想

看似简单的接口回调,实则蕴含大智慧。一种分层解决问题的最佳体现。

复杂的事情交给手下的人去做,自己只需要掌控大局即可。

这就是面向接口实现业务的好处,我们只需要继承接口,在实现类中完成相关的业务逻辑。即可!

模拟实现接口回调

回调接口

package callback;

/**
 * 模拟实现的接口回调
 *
 * @author Administrator
 *
 */
public interface ResultSetHandler {
    /**
     * 用于分配给实现类的抽象方法
     *
     * @param str
     * @return
     */
    public Object handler(String str);

}

接口的实现类

接口的实现类完全可以按照自己的需求来实现,下面罗列几个常见的实现类。

  • HeadHandler.java
package callback;

public class HeadHandler implements ResultSetHandler {

    /**
     * 截取字符串的前三个字符
     */
    @Override
    public Object handler(String str) {
        return str.substring(str.length() - str.length() + 1, str.length() - str.length() + 3);
    }

}
  • TailHandler.java
package callback;

public class TailHandler implements ResultSetHandler {

    /**
     * 截取字符串的后三个字符
     */
    @Override
    public Object handler(String str) {
        return str.subSequence(str.length() - 3, str.length());
    }

}
  • UpperCaseHandler.java
package callback;

public class UpperCaseHandler implements ResultSetHandler {

    /**
     * 将字符串转换为大写方式来输出
     */
    @Override
    public Object handler(String str) {
        return str.toUpperCase();
    }

}
  • DownCaseHandler.java
package callback;

public class DownCaseHandler implements ResultSetHandler {

    /**
     * 将字符串转换为小写方式来输出
     */
    @Override
    public Object handler(String str) {
        return str.toLowerCase();
    }

}

类QueryRunner的StrUtils实现

package callback;

public class StrUtils {

    /**
     * 模拟QueryRunner实现的StrUtils,大管家
     *
     * @param origin
     * @param handler
     * @return
     */
    public static Object query(String origin, ResultSetHandler handler) {
        return handler.handler(origin);
    }

}

测试

测试类代码

package callback;

public class Test {

    public static void main(String[] args) {
        String testStr = "aBcDEfghIjKLMnoPQrStuVwXyZ";
        String result = (String) StrUtils.query(testStr, new HeadHandler());
        System.out.println("Origin Str: " + testStr);
        System.out.println("Result Str: " + result);
        System.out.println("---------------------------------");
        result = (String) StrUtils.query(testStr, new TailHandler());
        System.out.println("Origin Str: " + testStr);
        System.out.println("Result Str: " + result);
        System.out.println("---------------------------------");
        result = (String) StrUtils.query(testStr, new UpperCaseHandler());
        System.out.println("Origin Str: " + testStr);
        System.out.println("Result Str: " + result);
        System.out.println("---------------------------------");
        result = (String) StrUtils.query(testStr, new DownCaseHandler());
        System.out.println("Origin Str: " + testStr);
        System.out.println("Result Str: " + result);
    }

}

测试结果

Origin Str: aBcDEfghIjKLMnoPQrStuVwXyZ
Result Str: cDEfg
---------------------------------
Origin Str: aBcDEfghIjKLMnoPQrStuVwXyZ
Result Str: XyZ
---------------------------------
Origin Str: aBcDEfghIjKLMnoPQrStuVwXyZ
Result Str: ABCDEFGHIJKLMNOPQRSTUVWXYZ
---------------------------------
Origin Str: aBcDEfghIjKLMnoPQrStuVwXyZ
Result Str: abcdefghijklmnopqrstuvwxyz

总结

以模拟的方式来学习比较适合我,所以模拟DbUtils来简单的实现自己的StrUtils,是一件非常快乐的事情。从中我能感受到那些优秀的框架设计人员的智慧,真的是让人佩服。真希望有一天自己也能成为那样的大牛!

在这个接口回调的实例中,我最大的收获就是面向接口的编程方式,以及复杂事情交给实现类去完成的“至简”思想。

模拟DbUtils实现接口回调机制的更多相关文章

  1. (转)Android之接口回调机制

    开发中,接口回调是我们经常用到的. 接口回调的意思即,注册之后并不立马执行,而在某个时机触发执行. 举个例子: A有一个问题不会,他去问B,B暂时解决不出来,B说,等我(B)解决了再告诉你(A)此时A ...

  2. 弄明白Android 接口回调机制

    以前对于这个机制理解不够深刻,现在重新整理下思路. 一.建模 我理解的接口回调就是,我这个类实现了一个接口里的方法doSomething,然后注册到你这里,然后我就去做别的事情去了,你在某个触发的时机 ...

  3. Java接口回调机制

    一.前言 最近在看android Fragment与Activity进行数据传递的部分,看到了接口回调的内容,今天来总结一下. 二.回调的含义和用途 1.什么是回调? 一般来说,模块之间都存在一定的调 ...

  4. Android接口回调机制

    开发中,接口回调是我们经常用到的. 接口回调的意思即,注册之后并不立马执行,而在某个时机触发执行. 举个例子: A有一个问题不会,他去问B,B暂时解决不出来,B说,等我(B)解决了再告诉你(A)此时A ...

  5. 关于android接口回调机制

    http://www.cnblogs.com/JohnTsai/p/3975022.html http://www.zhihu.com/question/19801131 In my previous ...

  6. 深入浅出: Java回调机制(异步)

    一.什么是回调 回调,回调.要先有调用,才有调用者和被调用者之间的回调.所以在百度百科中是这样的: 软件模块之间总是存在着一定的接口,从调用方式上,可以把他们分为三类:同步调用.回调和异步调用. 回调 ...

  7. Android 中的接口回调

    http://blog.csdn.net/wangjinyu501/article/details/22052187   在Android中到处可见接口回调机制,尤其是UI事件处理方面.举一个最常见的 ...

  8. Android实战之 万能的接口回调

    转载请标明原地址:http://blog.csdn.net/gaolei1201/article/details/47084111 前言:本人也算是自学"成才",呵呵,大学时尽管学 ...

  9. 模拟QQ侧滑控件 实现三种界面切换效果(知识点:回调机制,解析网络json数据,fragment用法等)。

    需要用到的lib包 :解析json  gson包,从网络地址解析json数据成String字符串的异步网络解析工具AsyncHttpClient等 下载地址:点击下载 Xlistview 下拉上拉第三 ...

随机推荐

  1. 半径无关快速高斯模糊实现(附完整C代码)

    之前,俺也发过不少快速高斯模糊算法. 俺一般认为,只要处理一千六百万像素彩色图片,在2.2GHz的CPU上单核单线程超过1秒的算法,都是不快的. 之前发的几个算法,在俺2.2GHz的CPU上耗时都会超 ...

  2. 简陋的个人Vim使用命令

    最近把Visual Studio 的编辑器改成了 Vim,感觉像发现了新世界,记录记录一些提高效率的Vim命令. 插入命令 i 在当前位置前插入 I 在当前行首插入 a 在当前位置后插入 A 在当前行 ...

  3. ABP领域层知识回顾之---工作单元

    1. 前言   在上一篇博文中(http://www.cnblogs.com/xiyin/p/6842958.html) 我们讲到了ABP领域层的仓储.这边博文我们来讲 工作单元.个人觉得比较重要.文 ...

  4. [HAOI 2011]Problem b

    Description 对于给出的n个询问,每次求有多少个数对(x,y),满足a≤x≤b,c≤y≤d,且gcd(x,y) = k,gcd(x,y)函数为x和y的最大公约数. Input 第一行一个整数 ...

  5. [TJOI 2016&HEOI 2016]排序

    Description 在2016年,佳媛姐姐喜欢上了数字序列.因而他经常研究关于序列的一些奇奇怪怪的问题,现在他在研究一个难题 ,需要你来帮助他.这个难题是这样子的:给出一个1到n的全排列,现在对这 ...

  6. [USACO13DEC]假期计划(黄金)Vacation Planning (gold)

    题目翻译不好,这里给出一份 题目背景 Awson是某国际学校信竞组的一只大佬.由于他太大佬了,于是干脆放弃了考前最后的集训,开车(他可是老司机)去度假.离开学校前,他打开地图,打算做些规划. 题目描述 ...

  7. bzoj 3451 Normal

    Description 某天WJMZBMR学习了一个神奇的算法:树的点分治! 这个算法的核心是这样的: 消耗时间=0 Solve(树 a) 消耗时间 += a 的 大小 如果 a 中 只有 1 个点 ...

  8. [BZOJ]1177: [Apio2009]Oil

    题目大意:给出一个n*m的矩阵,选出3个不相交的k*k子矩阵,使得子矩阵中元素和最大.(k<=n,m<=1500) 思路:选出的子矩阵有3种情况:横着排三个.竖着排三个.三角状分布(其中有 ...

  9. 2015 多校联赛 ——HDU5302(构造)

    Connect the Graph Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/65536 K (Java/Others ...

  10. [BZOJ]1069 最大土地面积(SCOI2007)

    计算几何经典题,贴板子. Description 在某块平面土地上有N个点,你可以选择其中的任意四个点,将这片土地围起来,当然,你希望这四个点围成的多边形面积最大. Input 第1行一个正整数N,接 ...