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

来源:互联网 发布:linux如何卸载jenkins 编辑:程序博客网 时间:2024/04/28 14:50
饿汉式
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);  }  }  }


	
				
		
原创粉丝点击