装饰者模式: 我是一个没有感情的杀手

在复习到自建数据库连接池的时候有点蒙了,再次翻看视频整理如下:(装饰者模式下自建数据库连接池修改close功能为 回收连接对象)

自备材料:数据库连接对象的获取的工具类 jdbcUtils(产出数据库连接对象getConnection 以及 释放资源的close)

—————————————————————————————————————————————————

public class MyDataSource implements DataSource {
  List <Connection> list = new ArrayList<>();        //用来存放连接对象的集合(可以看作是一个池子)
  public MyDataSource() {                //构造方式中创建了10个连接对象,放到池子中
    for (int i = 0; i < 10; i++) {
      Connection conn = JDBCUtil.getConn();
      list.add(conn);
    }
  }

  @Override
  public Connection getConnection() throws SQLException {
    if(list.size() == 0 ){                  //获取连接对象之前自检一边池子中是否还有多余连接对象
      for (int i = 0; i < 5; i++) {               //如果拿那完了  我们每次设定涨幅为5个 ,再创建五个
        Connection conn = JDBCUtil.getConn();
        list.add(conn);
      }
    }

    Connection conn = list.remove(0);                //remove()  移除并返回该对象,我们就获得了一个连接池对象,且池子中也相应的减少
    Connection connection = new ConnectionWrap(conn, list);   //在把这个对象抛出去的时候, 对这个对象进行包装。(关键所在)
    return connection;                    //返回包装后的对象
  }

—————————————————————————————————————————————————

装饰者模式下的包装类

public class ConnectionWrap implements Connection{           
  Connection connection = null;
  List <Connection> list ;
  public ConnectionWrap(Connection connection , List <Connection> list) {   //为全局变量赋值 ,待会儿需要  
    super();
    this.connection = connection;
    this.list = list;
  }

  @Override
  public void close() throws SQLException {      //这个是我们要使用到的方法 所以对其进行装饰修改
    //connection.close();              //原本close() 是释放资源用的 现在我们不要他释放资源了  我们对其变更功能     
    list.add(connection);              //将该连接对象,回收到我们的池中中
  }
  @Override
  public PreparedStatement prepareStatement(String sql) throws SQLException {   //这个方法待会儿我们也要使用,但我们不打算更改,所以调用之前的方法即可
    return connection.prepareStatement(sql);
   }

.......

———————————————————————————————————————————————————

这样一套太极打下来:

  当我们从自建数据源 MyDataSource 中获取对象时, 返回给我们的对象是一个也实现Connection方法的 自建对象,  当我们要调用某个方法时,调用的是这个自建对象中方法,

    如果我们不想对某个方法进行改变, 但又需要时,  使用通过构造传来的那个对象的方法即可

装饰者的大概:

  实现相同的接口,被装饰类 通过装饰类的构造传入 ,作为装饰类的全局变量   想改变某个方式的逻辑时, 直接在装饰类中对应方法修改 ,如果不想改变 ,调用全局变量,启用被装饰类的方法

    在使用的时候, 我们就用装饰类,做我们想做的时候, 体现了多态的思想

装饰者模式&数据库连接池原理的更多相关文章

  1. JDBC数据库连接池原理

    JDBC是java数据库连接的简称.它是一种用于实行SQL语句的Java API,可以为多种关系数据库提供统一访问,它由一组用java语言编写的类和接口组成.其相关的API都在java.sql.*包下 ...

  2. Java数据库连接池原理与简易实现

    1.什么是数据库连接池 我们现在在开发中一定都会用到数据库,为了提高我们的系统的访问速度,数据库优化是一个有效的途径.我们现在开发中使用数据库一般都要经历以下的四个步骤:(1)加载数据库的驱动类,(2 ...

  3. JAVA和C#中数据库连接池原理与应用

    JAVA和C#中数据库连接池原理 在现在的互联网发展中,高并发成为了主流,而最关键的部分就是对数据库操作和访问,在现在的互联网发展中,ORM框架曾出不穷, 比如:.Net-Core的EFCore.Sq ...

  4. Java中数据库连接池原理机制的详细讲解以及项目连接数据库采用JDBC常用的几种连接方式

    连接池的基本工作原理 1.基本概念及原理 由上面的分析可以看出,问题的根源就在于对数据库连接资源的低效管理.我们知道,对于共享资源,有一个很著名的设计模式:资源池(Resource Pool).该模式 ...

  5. Java中数据库连接池原理机制的详细讲解

    连接池的基本工作原理 1.基本概念及原理 由上面的分析可以看出,问题的根源就在于对数据库连接资源的低效管理.我们知道,对于共享资源,有一个很著名的设计模式:资源池(Resource Pool).该模式 ...

  6. Java中数据库连接池原理机制的详细讲解(转)

    连接池的基本工作原理 1.基本概念及原理 由上面的分析可以看出,问题的根源就在于对数据库连接资源的低效管理.我们知道,对于共享资源,有一个很著名的设计模式:资源池 (Resource Pool).该模 ...

  7. DBCP数据库连接池原理分析

    在比较大的项目中,需要不断的从数据库中获取数据,Java中则使用JDBC连接数据库,但是获取数据库的连接可是相当耗时的操作,每次连接数据库都获得 .销毁数据库连接,将是很大的一个开销.为了解决这种开销 ...

  8. SpringBoot 2.0 中 HikariCP 数据库连接池原理解析

    作为后台服务开发,在日常工作中我们天天都在跟数据库打交道,一直在进行各种CRUD操作,都会使用到数据库连接池.按照发展历程,业界知名的数据库连接池有以下几种:c3p0.DBCP.Tomcat JDBC ...

  9. 数据库连接池原理 与实现(动脑学院Jack老师课后自己的练习有感)

    第一步: 首先创建一个数据库连接池的接口: 数据库连接池接口有两个主要的方法,其中一个getConnection();  通过数据库连接池返回给用户封装的数据库连接对象 createConnectio ...

随机推荐

  1. 【Linux】Tree命令安装和使用

    Tree命令简介 tree是一种递归目录列表命令,产生一个深度缩进列表文件,这是彩色的ALA dircolors如果ls_colors设置环境变量和输出是TTY.树已经被移植和报道以下操作系统下工作: ...

  2. python之函数篇3

    一:函数的定义 1)函数的简单使用,无参函数 def f1(): # 定义函数指定函数名 print("hello") # 指定功能 f1() # 调用函数,才能执行函数体里面的功 ...

  3. Servlet------EL表达式

    EL表达式是: Expression Language.一种写法非常简介的表达式.语法简单易懂,便于使用..获取作用域的数据.... 对比: 传统方式获取作用域数据:                缺 ...

  4. 2018.11.02 NOIP模拟 飞越行星带(最小生成树/二分+并查集)

    传送门 发现题目要求的就是从下到上的瓶颈路. 画个图出来发现跟去年noipnoipnoip提高组的奶酪差不多. 于是可以二分宽度+并查集检验,或者直接求瓶颈. 代码

  5. .net 根据网址生成静态页

    生成HTML页面代码 public int Htmls(int id) { ; string strHtmlContent = ""; HttpWebRequest request ...

  6. 01-Javascript简介

    Web前端有三层: HTML:从语义的角度,描述页面结构 CSS:从审美的角度,描述样式(美化页面) JavaScript:从交互的角度,描述行为(提升用户体验) JavaScript的组成 Java ...

  7. 利用tcpcopy引流过程

    tcpcopy是一个tcp流量复制工具,当前还支持udp和mysql流量的复制. 目的: 将机器10.24.110.21的5000端口流量引流到机器10.23.25.11的5000端口. 示例:将10 ...

  8. command not found Operation not permitted

    mysql -uroot -p  报错误:command not found 因为苹果在OS X 10.11中引入的SIP特性使得即使加了sudo(也就是具有root权限)也无法修改系统级的目录,其中 ...

  9. Fortran编译器之一GUN Fortran安装(Windows XP)

    最近研究GIS算法,需要用到Fortran语言.在网上找了一下发现一个开源的软件GUN Fortran编译器.当然既然是编译器,就是编译出程序的,但是编辑器不包括在内.编辑器可以用Text记事本,或者 ...

  10. Hdu1205 吃糖果 2017-06-29 14:26 24人阅读 评论(0) 收藏

    吃糖果 Problem Description HOHO,终于从Speakless手上赢走了所有的糖果,是Gardon吃糖果时有个特殊的癖好,就是不喜欢将一样的糖果放在一起吃,喜欢先吃一种,下一次吃另 ...