zoukankan      html  css  js  c++  java
  • java实现23种设计模式之享元模式

    享元模式的主要目的是实现对象的共享,即共享池,当系统中对象多的时候可以减少内存的开销,通常与工厂模式一起使用

    FlyWeightFactory负责创建和管理享元单元,当一个客户端请求时,工厂需要检查当前对象池中是否有符合条件的对象,
    如果有,就返回已经存在的对象,如果没有,则创建一个新对象,FlyWeight是超类。
    一提到共享池,我们很容易联想到Java里面的JDBC连接池,想想每个连接的特点,
    我们不难总结出:适用于作共享的一些个对象,他们有一些共有的属性,就拿数据库连接池来说,url、driverClassName、username、password及dbname,
    这些属性对于每个连接来说都是一样的,所以就适合用享元模式来处理,建一个工厂类,将上述类似属性作为内部数据,其它的作为外部数据,
    在方法调用时,当做参数传进来,这样就节省了空间,减少了实例的数量。
    package com.ceshi11;
    
    import java.sql.Connection;
    import java.sql.DriverManager;
    import java.sql.SQLException;
    import java.util.Vector;
    
    public class ConnectionPool {
    private Vector<Connection> pool;
        
        /*公有属性*/
        private String url = "jdbc:mysql://localhost:3306/test";
        private String username = "root";
        private String password = "root";
        private String driverClassName = "com.mysql.jdbc.Driver";
    
        private int poolSize = 100;
        private static ConnectionPool instance = null;
        Connection conn = null;
    
        /*构造方法,做一些初始化工作*/
        private ConnectionPool() {
            pool = new Vector<Connection>(poolSize);
    
            for (int i = 0; i < poolSize; i++) {
                try {
                    Class.forName(driverClassName);
                    conn = DriverManager.getConnection(url, username, password);
                    pool.add(conn);
                } catch (ClassNotFoundException e) {
                    e.printStackTrace();
                } catch (SQLException e) {
                    e.printStackTrace();
                }
            }
        }
    
        /* 返回连接到连接池 */
        public synchronized void release() {
            pool.add(conn);
        }
    
        /* 返回连接池中的一个数据库连接 */
        public synchronized Connection getConnection() {
            if (pool.size() > 0) {
                Connection conn = pool.get(0);
                pool.remove(conn);
                return conn;
            } else {
                return null;
            }
        }
    }

    如果不存在这个链接,则创建一个链接在连接池中。减少对象的创建,降低系统的内存,使效率提高。

    通过连接池的管理,实现了数据库连接的共享,不需要每一次都重新创建连接,节省了数据库重新创建的开销,提升了系统的性能!

  • 相关阅读:
    jfreechart各种图表生成源码练习
    已知两圆圆心坐标及半径求两圆交点 (C语言|参数方程求解)
    关于“Internet Explorer无法打开站点,已终止操作”的解决方法
    用批处理编译VC2008工程
    NET 3.5 SP1和VS2008 SP1 Beta版
    "Couldn't find installable ISAM."这条错误信息,什么含义?
    ArcGIS Server 开发系列(二)Web ADF 编程 (转载于Flyingis)
    ArcGIS Server 开发系列(一)编程框架总览 (转载于Flyingis)
    雅虎公司C#笔试题
    datagrid的即时刷新
  • 原文地址:https://www.cnblogs.com/zhengyuanyuan/p/10750411.html
Copyright © 2011-2022 走看看