经过之前的项目构建,我们已经得到了一个可以使用的最基本的项目。

其中已经包括整个执行的过程。但是我们在完成之后也遇到了很多问题,我们就要慢慢的一步步解决这些问题。

讲道理,今天我们其实应该直接开始看源码,看看第一步也就是SqlSessionFactoryBulider是如何创建工厂的了。

但是别急,兄弟,我们要求的是最仔细,而不是最快。

有两件很重要的装备我们还没有,现在看还早了一些。

今天就要讲述第一件重要的装备:生命周期。(如果之前和我一样都是使用Spring管理的MyBatis的话对它应该好好学习一下)

废话说多了,赶紧开始了。

简记名字

在说之前,因为每个组件的名字都太长了,我简单记作下面这样

SqlSessionFactoryBuilder---->Builder、构建者

SqlSessionFactory ----->Factory、工厂

SqlSession----->产品、会话

SqlMapper----->接口

各个组件的生命周期

构建者:他的作用就是创建一个工厂。那么仔细想想,当工厂建造完成之后,它就没什么用了。那么没用的东西,在java中肯定要回收掉了。

所以对于它来说,建造完成工厂之后就被回收了,所以它的生命周期应该只存在与方法的局部。

工厂:工厂的作用是产生产品。那么仔细想想,工厂可不能生产一个产品之后就挂掉了。所以它肯定不能马上就被回收掉。

所以对于工厂来说,我们对于一个应用会不停的要求产品,所以它的生命周期应该整个应用中。

但是,少了不行,但是如果太多行不行呢?

按照现实情况来说,建造一个工厂成本挺大的吧,会占用很多面积吧,所以工厂肯定建造不了太多了。

按照程序的角度来说呢,一个工厂就占用了一个数据库连接,我们知道数据库的连接数是有限的,如果占用的太多,那么肯定是不行的。

所以我们这里可以采用单例模式,只建立一个工厂,我们只要从这个工厂里面拿产品就可以了。这也就是这个工厂存在的意义了。

产品:对于产品来说,功能就是去执行一个对应的mapper,那么显然,执行完成之后,这个产品就没有用了,要赶紧回收,不然占用了别人操作数据库的机会就不好了。

所以产品的生命周期挺短的,应该是在请求数据库处理事物的过程中。而且回收的代码需要放在finally中,也就是无论出现什么情况都要回收,不能浪费。

mapper:这个就很好办了,产品造就它,它就出现了,产品销毁了,那么他也就没了。

设计单例模式

现在这件装备爆出来了,赶紧捡起来咯。

当我们知道了这些组件的生命周期之后,我们显然要对我们之前的代码进行调整了,这里设计一个最简单的单例模式来满足那个建造者的要求咯。

我们先看一下最简单最基本的单例模式的实现。

public class Singleton {
private volatile static Singleton singleton;
private Singleton (){}
public static Singleton getSingleton() {
if (singleton == null) {
synchronized (Singleton.class) {
if (singleton == null) {
singleton = new Singleton();
}
}
}
return singleton;
}
}

基本上就是上面这个样子啦。具体原理我这边就不多说了,如果对于上面代码有疑问的话就要好好补补基础咯。

然后照着这个基本的样子就可以基本实现我们的要求了。

import org.apache.ibatis.io.Resources;
import org.apache.ibatis.session.SqlSessionFactory;
import org.apache.ibatis.session.SqlSessionFactoryBuilder; import java.io.IOException;
import java.io.InputStream; public class SqlSessionFactoryBuilderTest { private volatile static SqlSessionFactory sqlSessionFactory = null;
private SqlSessionFactoryBuilderTest(){}
public static SqlSessionFactory getSqlSessionFactory(){
if (sqlSessionFactory == null){
synchronized (SqlSessionFactoryBuilderTest.class){
if (sqlSessionFactory == null){
String resource = "mybatis-config.xml";
InputStream inputStream = null;
try {
inputStream = Resources.getResourceAsStream(resource);
} catch (IOException e) {
e.printStackTrace();
}
sqlSessionFactory = new SqlSessionFactoryBuilder().build(inputStream);
}
}
}
return sqlSessionFactory;
}
}

然后修改一下主要测试类

public class MainTest {

    public static void main(String[] args) throws Exception {
SqlSessionFactory sqlSessionFactory = SqlSessionFactoryBuilderTest.getSqlSessionFactory();
SqlSession session = sqlSessionFactory.openSession();
try {
Demo demo = (Demo) session.selectOne("com.xex.dao.mapper.DemoMapper.selectDemo");
System.out.println(demo.getValue());
} finally {
session.close();
}
}
}

到此为止我们已经完成了单例模式

通过了对于各个组件生命周期的了解,我们修改了我们的代码,让它更加贴近实际一些。

我们也解决了部分我们在之前提出的问题。

这一章这对于我们以后学习源码是一个基础,需要掌握。

MyBatis源码解析【3】生命周期的更多相关文章

  1. 【MyBatis源码解析】MyBatis一二级缓存

    MyBatis缓存 我们知道,频繁的数据库操作是非常耗费性能的(主要是因为对于DB而言,数据是持久化在磁盘中的,因此查询操作需要通过IO,IO操作速度相比内存操作速度慢了好几个量级),尤其是对于一些相 ...

  2. Mybatis源码解析(一) —— mybatis与Spring是如何整合的?

    Mybatis源码解析(一) -- mybatis与Spring是如何整合的?   从大学开始接触mybatis到现在差不多快3年了吧,最近寻思着使用3年了,我却还不清楚其内部实现细节,比如: 它是如 ...

  3. Mybatis源码解析(四) —— SqlSession是如何实现数据库操作的?

    Mybatis源码解析(四) -- SqlSession是如何实现数据库操作的?   如果拿一次数据库请求操作做比喻,那么前面3篇文章就是在做请求准备,真正执行操作的是本篇文章要讲述的内容.正如标题一 ...

  4. Mybatis源码解析-DynamicSqlSource和RawSqlSource的区别

    XMLLanguageDriver是ibatis的默认解析sql节点帮助类,其中的方法其会调用生成DynamicSqlSource和RawSqlSource这两个帮助类,本文将对此作下简单的简析 应用 ...

  5. mybatis源码-解析配置文件(四-1)之配置文件Mapper解析(cache)

    目录 1. 简介 2. 解析 3 StrictMap 3.1 区别HashMap:键必须为String 3.2 区别HashMap:多了成员变量 name 3.3 区别HashMap:key 的处理多 ...

  6. mybatis源码-解析配置文件(四)之配置文件Mapper解析

    在 mybatis源码-解析配置文件(三)之配置文件Configuration解析 中, 讲解了 Configuration 是如何解析的. 其中, mappers作为configuration节点的 ...

  7. mybatis源码-解析配置文件(三)之配置文件Configuration解析

    目录 1. 简介 1.1 系列内容 1.2 适合对象 1.3 本文内容 2. 配置文件 2.1 mysql.properties 2.2 mybatis-config.xml 3. Configura ...

  8. Mybatis源码解析,一步一步从浅入深(一):创建准备工程

    Spring SpringMVC Mybatis(简称ssm)是一个很流行的java web框架,而Mybatis作为ORM 持久层框架,因其灵活简单,深受青睐.而且现在的招聘职位中都要求应试者熟悉M ...

  9. Mybatis源码解析,一步一步从浅入深(二):按步骤解析源码

    在文章:Mybatis源码解析,一步一步从浅入深(一):创建准备工程,中我们为了解析mybatis源码创建了一个mybatis的简单工程(源码已上传github,链接在文章末尾),并实现了一个查询功能 ...

  10. Mybatis源码解析,一步一步从浅入深(三):实例化xml配置解析器(XMLConfigBuilder)

    在上一篇文章:Mybatis源码解析,一步一步从浅入深(二):按步骤解析源码 ,中我们看到 代码:XMLConfigBuilder parser = new XMLConfigBuilder(read ...

随机推荐

  1. java面向对象--继承与多态

    可以为一个变异单元中的每个类创建一个main方法,只有命令行所调用的那个类的main方法才会被调用,这样方便进行单元测试.继承时,一般将所有的数据成员都指定为private,将所有的方法指定为publ ...

  2. Java中 EvenQueue.invokeLater用法

    在Java中Swing是线程不安全的,是单线程的设计,这样的造成结果就是:只能从事件派发线程访问将要在屏幕上绘制的Swing组件.事件派发线程是调用paint和update等回调方法的线程,它还是事件 ...

  3. OpenStack dashboard界面操作 实现登陆虚拟机并通信

    1.创建项目,点击"创建项目" (1).填写项目信息 (2).添加与之关联的项目成员 (3).点击"配额",为用户在平台上分配一个操作的空间,便于用户创建网络, ...

  4. Android Weekly Notes Issue #258

    Android Weekly Issue #258 May 21st, 2017 Android Weekly Issue #258 本期内容: 围绕着Google I/O的热潮, 本周的posts除 ...

  5. 中文分词中的战斗机-jieba库

    英文分词的第三方库NLTK不错,中文分词工具也有很多(盘古分词.Yaha分词.Jieba分词等).但是从加载自定义字典.多线程.自动匹配新词等方面来看. 大jieba确实是中文分词中的战斗机. 请随意 ...

  6. 一天搞定HTML----标签类型与类型转换05

    标签类型: 标签只有两类:行内元素和块元素 行内元素:内容撑开宽高 块元素:默认独占一行 注意: 在使用display时,会遇到一种inline-block类型的标签.这种标签不属于标签的分类. 1. ...

  7. 网络编程4之UDP协议

    一.定义 UDP 是User Datagram Protocol的简称, 中文名是用户数据报协议,是OSI(Open System Interconnection,开放式系统互联) 参考模型中一种[无 ...

  8. 4.Node.js 微信消息管理

    一.写在前面的话   当用户发送消息给公众号时(或某些特定的用户操作引发的事件推送时),会产生一个POST请求,开发者可以在响应包(Get)中返回特定XML结构,来对该消息进行响应.   消息推送也是 ...

  9. 在Quo.js下Tap和singleTap的区别

    前两天上网搜开发手机页面的JS,看到了Quo.js下载下来后来看了一下,支持的触屏手势挺多的,在一般的开发中应该够用了,更让我喜欢它的一点是它跟JQ差不多(虽然功能不如JQ强大但是语法基本一致).这就 ...

  10. 关于cas server无法通过session持久化方式实现集群的问题

    最近在搭建cas单点登录系统 ,在建立集群时发生一个问题. 搭建的环境是tomcat+tomcat-redis-session-manager+redis+cas 在对tomcat的session进行 ...