SingletonPattern(23种设计模式之一)

时间:2023-11-10 08:03:37

设计模式六大原则(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();
                }
            }
        }
    }
}

别嫌弃我没写注释,这个代码很简单,注释省略,嘿嘿。