单例模式---Java设计模式

饿汉式
class Singleton {
  private static Singleton instance=new Singleton();
  private Singleton(){}
  static Singleton getInstance() {
      return instance;
  }
}

懒汉式
class Singleton {
  private static Singleton instance=null;
  private Singleton(){}
  static Singleton getInstance() {
      if(instance==null)
      instance=new Singleton();
      return instance;
  }
}

 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;   } #p# #e#   /**   * 此方法提供一个可用的数据库连接,从连接池中取得可用连接   *   * @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);   }   }   }

 

                
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值