设计模式六大原则(1):单一职责原则
设计模式六大原则(2):里氏替换原则
设计模式六大原则(3):依赖倒置原则
设计模式六大原则(4):接口隔离原则
设计模式六大原则(5):迪米特法则
设计模式六大原则(6):开闭原则
SingletonPattern,UML抽象图百度找,代码实现如下
使用单例模式设计一个可以创建数据库连接的类。
单例类
package jiwei;
import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.ResultSet;
import java.sql.SQLException;
import java.sql.Statement;
public final class jdbcUtils {
private static String url="数据库URL";
private static String user="用户名";
private static String password="密码";
//url:jdbc:子协议:子名称//[(当为本地时可省略)主机名:端口]/数据库名?属性名=属性值&...
/**
* @param args
*/
private static Connection instance=null;
private jdbcUtils(){ //不构造实例
}
static{ //静态代码块只被执行一次(类被装载到虚拟机时被执行)
try {
// 注册驱动
// DriverManager.registerDriver(new com.mysql.jdbc.Driver()); //必须有架包存在
// System.setProperty("jdbc.Driver", "com.mysql.jdbc.Driver");
Class.forName("com.mysql.jdbc.Driver"); //最佳方式 无架包依然可以通过编译
} catch (ClassNotFoundException e) {
// TODO Auto-generated catch block
throw new ExceptionInInitializerError(e);
}
}
public static Connection getConnection() throws SQLException{
if(instance==null){
instance = DriverManager.getConnection(url, user, pasword);
return instance;
}else{
return instance;
}
}
public static void free(ResultSet rs,Statement st,Connection conn){
try {
if (rs != null) {
rs.close();
}
} catch (SQLException e) {
e.printStackTrace();
} finally {
try {
if (st != null) {
st.close();
}
} catch (SQLException e) {
e.printStackTrace();
} finally {
try {
if (conn != null) {
myDataSource.free(conn);
}
} catch (Exception e) {
e.printStackTrace();
}
}
}
}
}
别嫌弃我没写注释,这个代码很简单,注释省略,嘿嘿。