单例模式

本文详细解析了Singleton模式在Java中的核心作用,即确保类仅有一个实例存在,适用于创建目录数据库连接等单线程操作场景。通过实例展示了如何实现单例模式,包括静态内部类方式和封装数据库连接的实现细节。同时阐述了单例模式的多态应用,如作为状态仓库提供服务,以及如何实现无状态化以提供工具性质功能。最后讨论了单例模式带来的内存节省和垃圾回收效率提升等优点。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

                                                                                                  设计模式之Singleton(单态)

定义:Singleton模式主要作用是保证在java应用程序中,一个类Class只有一个实例存在。

在很多操作中,比如建立目录 数据库连接都需要这样的单线程操作。

还有,Singleton能够被状态化,这样,多个单态类在一起可以作为一个状态仓库一样向外提供服务,比如,你要论坛中的帖子计数器,每次浏览一次需要计数,单态类能否保持住这个计数,并且能synchronize的安全自动加1,如果你要把这个数字永久保存到数据库,你可以在不修改单态接口的情况下方便做到。

另外方面,singleton也能够被无状态化,提供工具性质功能,Singleton模式就为我们提供了这样实现的可能。使用Singleton的好处在于可以节省内存,因为它限制了实例的个数,有利于java垃圾回收。

如何使用?

一般Singleton模式通常有几种形式:

1、public class Singleton {

 // 定义了一个私有的变量
 private static Singleton instance = new Singleton();

 /**
  * 私有构造器
  */
 private Singleton() {

 }

 /**
  * 提供供外界访问的这个方法 能获取私有的属性instance
  *
  * @return
  */
 public static Singleton getSingleton() {
  
  return instance;
 }

}

2、package www.youkuaiyun.com.util;

import java.io.File;
import java.io.FileInputStream;
import java.io.InputStream;
import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.ResultSet;
import java.sql.SQLException;
import java.sql.Statement;
import java.util.Properties;

/**
 * 简单模拟:单例模式的应用
 *
 * @author yaohongbo
 *
 */
public class JdbcUtil {

 //封装的私有成员
 private static Connection conn;

 /**
  * 私有构造器
  */
 private JdbcUtil() {

 }

 /**
  * 获取连接对象
  * @return
  */
 public static synchronized Connection getConn() {
  if (conn == null) {
   try {
    // 第一步加载驱动程序
    Class.forName("com.mysql.jdbc.Driver");

    File file = new File("src//jdbc.properties");
    InputStream is = new FileInputStream(file);

    Properties prop = new Properties();
    prop.load(is);

    // 第二步:获取连接对象
    conn = DriverManager.getConnection(prop.getProperty("url"),
      prop.getProperty("user"), prop.getProperty("pass"));

   } catch (Exception e) {
    // TODO Auto-generated catch block
    e.printStackTrace();
   }

  }

  return conn;
 }

 /**
  * 释放资源
  * @param stmt
  * @param rs
  */
 public static void release(Statement stmt, ResultSet rs) {
  if (rs != null) {
   try {
    rs.close();
   } catch (SQLException e) {
    // TODO Auto-generated catch block
    e.printStackTrace();
   }
  }
  if (stmt != null) {
   try {
    stmt.close();
   } catch (SQLException e) {
    // TODO Auto-generated catch block
    e.printStackTrace();
   }
  }
 }
}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值