单例:
常用于某些只需出现一次的实例,例如:数据库的连接获取,sql语句与preparedStatement与ResultSet的初始化,将其放置在同一个实例中,避免因多次获取数据库连接且未能正常关闭导致的数据库异常报错。
public class SqlInstance {
private Connection connection;
private PreparedStatement pst;
private ResultSet rs;
private String sql;
private static SqlInstance instance;
private SqlInstance() throws ClassNotFoundException, SQLException {
Class.forName("com.mysql.jdbc.Driver");
connection = DriverManager.getConnection("jdbc:mysql://localhost:3306/adjunct?user=root&password=6788259149a&useUnicode=true&characterEncoding=utf8&zeroDateTimeBehavior=convertToNull");
}
public static SqlInstance getInstance() throws SQLException, ClassNotFoundException {
if (instance == null) {
instance = new SqlInstance();
}
return instance;
}
}
即使多次调用使用的也是同一个连接
责任链:
常用于功能区分选择,即出现分支选择时使用,避免出现多个if或switch等判断语句,例如程序需求中有登录注册功能时,或在修改个人信息时挑选修改的内容。
需要注意的是,使用责任链模式时,会创建多个实体类,导致程序看着略显臃肿。
观察者:
常用于处理并行事物,例如对数据库的多个表中内容进行修改或删除。