免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
最近访问板块 发新帖
查看: 2330 | 回复: 0
打印 上一主题 下一主题

Singleton模式(转载) [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2010-01-07 20:52 |只看该作者 |倒序浏览

Java Singleton 模式用来保证在运行的应用程序中,一个Class只是实例化一次,也就是只有一个相应的对象存在。在 web 程序中我们会用一个核心的分配功能的Servlet程序,在这里我们就可以运用这种设计模式了。
一般Singleton模式通常有几种种形式:
第一种形式:
   定义一个类,它的构造函数为private的,它有一个static的private的该类变量,在类初始化时实例话,通过一个public的getInstance方法获取对它的引用,继而调用其中的方法。
public class Singleton {
    private Singleton(){}
   
    //在自己内部定义自己一个实例,是不是很奇怪?
    //注意这是private 只供内部调用
    private static Singleton instance = new Singleton();
   
    //这里提供了一个供外部访问本class的静态方法,可以直接访问
    public static Singleton getInstance() {
            return instance;
    }
}
第二种形式:
public class Singleton {
    private static Singleton instance = null;
  
     public static synchronized Singleton getInstance() {
                //这个方法比上面有所改进,不用每次都进行生成对象,只是第一次
                //使用时生成实例,提高了效率!
                if (instance==null)
                        instance=new Singleton();
                return instance; }
      }
例子:
/**
* 数据库连接管理类
*/
public class DBManager {
    private static Logger logger = Logger.getLogger(DBManager.class);
    /**
     * 本静态变量用来存放本系统启动时由Struts生成的连接池的数据源
     */
    private static DataSource datasource;
    /**
     * 由于本类使用单态设计模式,因此不允许在使用中通过New进行实例化,那么本类就要提供一个 此类的实例供外界使用,这就是供外界使用的实例
     */
    private static DBManager dbConManager = new DBManager();//类被加载时构建实例
    private DBManager() {
    }
    /**
     * 此静态方法用来向类的静态变量赋值,用来在系统中使用
     *
     * @param mydatasource
     *            传入的struts生成的数据源
     */
    public void setDatasource(DataSource mydatasource) {
        logger.info("设置数据源");
        if (datasource == null) {
            datasource = mydatasource;
        }
    }
    /**
     * 由于本类使用单态模式,不允许其他的类使用New进行创建实例 因此在这里提供一个共有的静态方法来向外界提供自己的一个实例。
     *
     * @return 返回本类的唯一实例
     */
    public static DBManager getInstance() {
        logger.info("获得数据库连接管理类的实例");
        return dbConManager;
    }
    /**
     * 此方法提供一个可用的数据库连接,从连接池中取得可用连接
     *
     * @return 可用的数据库连接
     * @throws java.lang.SQLException
     *             有可能要抛出的SQL异常
     */
    public Connection getConnection() throws SQLException {
        Connection conn = null;
        try {
            logger.info("从连接池中获得空闲的数据库连接");
            conn = datasource.getConnection();
            return conn;
        } catch (SQLException ex) {
            logger.error("DBManager.getConnection(获取数据库连接失败):[SQLException]"
                    + ex.getMessage());
            throw ex;
        }
    }
    /**
     * 这是一个用来关闭所有的数据库连接相关的打开对象的方法,这样作的好处是不用在每一次调用了sql之后 要写一大串的关闭操作。
     *
     * @param conn
     *            将要关闭的数据库连接
     * @param st
     *            将要关闭的数据库操作对象
     * @param pst
     *            将要关闭的预处理数据库操作对象
     * @param cst
     *            将要关闭的数据库存储过程调用对象
     * @param rst
     *            将要关闭的数据库记录集对象
     * @throws java.lang.Exception
     *             有可能要抛出的异常
     */
    public void closeAll(Connection conn, Statement st, PreparedStatement pst,
            CallableStatement cst, ResultSet rst) throws DBManagerException {
        try {
            if (rst != null) {
                rst.close();
            }
            if (st != null) {
                st.close();
            }
            if (pst != null) {
                pst.close();
            }
            if (cst != null) {
                cst.close();
            }
            if (conn != null) {
                conn.close();
            }
        } catch (SQLException e) {
            throw new DBManagerException("数据库对象关闭出错!"+e.getMessage(),e);
        }
    }
}


本文来自ChinaUnix博客,如果查看原文请点:http://blog.chinaunix.net/u2/67175/showart_2143393.html
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP