package Base; import java.sql.Connection; import java.sql.DriverManager; import java.sql.ResultSet; import java.sql.SQLException; import java.sql.Statement; //不可被继承的工具类 public final class JdbcUtilsSingleton { //私有化成员变量,防止影响其他类共有的变量 private String url = "jdbc:mysql://127.0.0.1:3306/jdbc"; private String username = "root"; private String password = "123456"; private static JdbcUtilsSingleton instance=null; //私有化构造函数,确保不被外部实例化 private JdbcUtilsSingleton(){ } /** * 考虑到并发需要枷锁 * @return */ public static JdbcUtilsSingleton getInstance(){ if(instance == null){ synchronized(JdbcUtilsSingleton.class){ if(instance == null){ instance = new JdbcUtilsSingleton(); } } } return instance; } //加载JVM时只创建一次连接 static{ try { Class.forName("com.mysql.jdbc.Driver"); } catch (ClassNotFoundException e) { // TODO Auto-generated catch block e.printStackTrace(); } } //获取连接 public Connection getConnection() throws SQLException{ return DriverManager.getConnection(url, username, password); } //规范释放资源方法 public void Free(ResultSet rs,Statement stmt,Connection conn){ try{ if(rs != null) rs.close(); }catch(SQLException e){ e.printStackTrace(); }finally{ try{ if(stmt != null) stmt.close(); }catch(SQLException ex){ ex.printStackTrace(); }finally{ try{ if(conn != null) conn.close(); }catch(SQLException em){ em.printStackTrace(); } } } } }
单例模式要点总结:
1.私有化instance类变量和构造函数,确保不被外部实例化对象,保证唯一单一实例。
2.考虑到程序并发处理需要加锁
3.通过唯一入口静态方法获取实例:getInstance()