Java

本类阅读TOP10

·使用MyEclipse开发Struts框架的Hello World!(录像1)
·hibernate配置笔记
·AOP编程入门--Java篇
·linux下Tomcat 5.0.20 与 Apache 2 安装/集成/配置
·在win2003下整合了整合Tomcat5.5+ apache_2.0.53+ mod_jk_2.0.47.dll
·构建Linux下IDE环境--Eclipse篇
·Jsp 连接 mySQL、Oracle 数据库备忘(Windows平台)
·ASP、JSP、PHP 三种技术比较
·Tomcat5.5.9的安装配置
·AWT GUI 设计笔记(二)

分类导航
VC语言Delphi
VB语言ASP
PerlJava
Script数据库
其他语言游戏开发
文件格式网站制作
软件工程.NET开发
Singleton设计模式介绍

作者:未知 来源:月光软件站 加入时间:2005-5-13 月光软件站

Singleton就是单元素设计模式,该设计模式确保了在一个运用程序中,无论合饰地,这个类就只有一个实例可用.

适用范围.这种设计模式经常用于数据源库连接池对象等方面.因为无论你是从程序中的任何部分需要访问数据库,都是从该连接池中取出一个连接,用完后,再将连接放会连接池中.因此仅只需要一个连接池实例,该实例从第一次访问初始化,到运用程序关闭,他的生命周期才结束.

这种设计模式最大的特点是构造器设为私有,再申明一个类型为自己本身的静态私有变量myself,然后编写一个获取该类实例的静态公有方法(一般使用方法名为"getInstance()",你用其他名字也可以,但是这是一个约定俗成的规范),在这个方法中,判断,如果myself未被初始化,说明是第一次访问该对象,则调用私有构造器对myself进行初始化,然后返回myself,如果myslef已经被初始化,那直接返回myself.

下面我就以编写一个数据库连接池类来具体说明一下这种设计模式.

假设你已经在你的web容器中配制好了一个名为"jdbc/xxx"的数据源

package xxx;

import java.sql.SQLException;
import java.sql.Connection;
import javax.sql.DataSource;

import javax.naming.Context;
import javax.naming.InitialContext;
import javax.naming.NamingException;

import java.util.Properties;

public class ConnectionPool {
   
    private static String JDNI_NAME = "java:comp/env/jdbc/xxx";
    private DataSource ds;
    //申明一个类型为自己本身的变量
    [b]private static ConnectionPool mySelf;[/b]

    /**
     * 定义一个私有的构造器
     * @param ds DataSource
     */
    [b]private ConnectionPool(DataSource ds)[/b] {

        this.ds = ds;
    }

    /**
     * 获取类实例的方法
     * @return ConnectionPool
     */
    [b]public static ConnectionPool getInstance() [/b]{

        try {
            //如果myself未被初始化过
            if (mySelf == null) {
                Context initCtx = new InitialContext();
                if (initCtx == null) {
                    throw new NamingException("error.context.init");
                }
                DataSource ds = (DataSource) initCtx.lookup(JDNI_NAME);
               //调用私有构造器对其进行实例化
                [b]mySelf = new ConnectionPool(ds);[/b]
            }
            [b]return mySelf;[/b]
        } catch (NamingException ne) {
            ne.printStackTrace();
            throw new RuntimeException("error.connectionpool.getinstance");
        }
    }

    /**
     * 获取连接方法
     * @param autoCommit boolean
     * @return Connection
     * @throws SQLException
     */
    public Connection getConnection(boolean autoCommit) throws SQLException {
        Connection con = ds.getConnection();
        con.setAutoCommit(autoCommit);
        return con;

    }
}




相关文章

相关软件