博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
设计模式之模板模式
阅读量:2402 次
发布时间:2019-05-10

本文共 3385 字,大约阅读时间需要 11 分钟。

1. 模板模式使用场景

模板模式是大家常见的设计模式之一,相信你早已使用过JdbcTemplate、RestTemplate等,很显然这就是模板模式的体现。

 

2. 代码实现

我们以封装数据库操作的JdbcTemplate为例。

public class JdbcTemplate {	private DataSource dataSource;		public JdbcTemplate(DataSource dataSource) {		this.dataSource = dataSource;	}		private Connection getConnection() throws SQLException {		return this.dataSource.getConnection();	}		private PreparedStatement createPreparedStatement(Connection conn, String sql) throws SQLException {		return  conn.prepareStatement(sql);	}		private ResultSet executeQuery(PreparedStatement ps, RowMapper
rowMapper, Object[] values) throws SQLException { for (int i = 0; i < values.length; i++) { ps.setObject(i,values[i]); } return ps.executeQuery(); } private void closeStatement(Statement st) throws Exception{ st.close(); } private void closeResultSet(ResultSet rs) throws Exception{ rs.close(); } private void closeConnection(Connection conn) throws Exception{ conn.close(); } private List parseResultSet(ResultSet rs,RowMapper rowMapper) throws Exception{ List result = new ArrayList(); int rowNum = 1; while (rs.next()){ result.add(rowMapper.mapRow(rs,rowNum ++)); } return result; } public List executeQuery(String sql,RowMapper
row,Object [] values){ try { // 1.获取连接 Connection conn = this.getConnection(); // 2.创建语句集 PreparedStatement ps = this.createPreparedStatement(conn,sql); // 3.执行语句集,获取结果集 ResultSet res = ps.executeQuery(); // 4.解析语句集 List result = this.parseResultSet(res, null); // 5.关闭结果集 this.closeResultSet(res); // 6.关闭语句集 this.closeStatement(ps); // 7.关闭连接 this.closeConnection(conn); return result; } catch (Exception e) { e.printStackTrace(); } return null; } public DataSource getDataSource() { return dataSource; } public void setDataSource(DataSource dataSource) { this.dataSource = dataSource; } }
public interface RowMapper
{ public T mapRow(ResultSet rs, int rowNum) throws Exception; }
public class Member {    private String username;    private String password;    private String nickName;    private int age;    private String addr;    //get&set略}
//这里我们不进行继承JdbcTemplate类,原因是继承会重写很多方法public class MemberDao{	private JdbcTemplate jdbc = new JdbcTemplate(null);			public List query(){		String sql = "SELECT * FORM member ";		return jdbc.executeQuery(sql,new RowMapper
() { public Member mapRow(ResultSet rs, int rowNum) throws Exception{ Member member = new Member(); member.setUsername(rs.getString("username")); member.setPassword(rs.getString("password")); member.setAge(rs.getInt("age")); member.setAddr(rs.getString("addr")); return member; } },null); } public Object processResult(ResultSet rs, int rowNum)throws Exception { Member member = new Member(); member.setUsername(rs.getString("username")); member.setPassword(rs.getString("password")); member.setAge(rs.getInt("age")); member.setAddr(rs.getString("addr")); return member; } }
public class MemberDaoTest {	public static void main(String[] args) {		MemberDao memberDao = new MemberDao();		memberDao.query();	}	}

3. 总结

模板模式优点很明显,定义统一的执行标准,对于调用者不需要关系具体实现逻辑。它可以把公共的代码写在父类抽象类中,提高了代码的复用性,减少重复代码。父类进行行为管控,在子类中可以对父类方法进行扩展,具有扩展性,不同子类方法处理的灵活性。

模板模式的缺点是:由于继承关系父类的方法,子类都要重写一遍。

 

 

转载地址:http://wnpob.baihongyu.com/

你可能感兴趣的文章
Win2K无盘终端网组建全攻略(4)(转)
查看>>
Win2K无盘终端网组建全攻略(2)(转)
查看>>
[灾难备份]拿什么拯救你我的金融数据(转)
查看>>
忘记XP登录口令后的应急办法(转)
查看>>
Win2K无盘终端网组建全攻略(1)(转)
查看>>
WIN2000/NT密码全攻略(转)
查看>>
XP命令行加密功能(转)
查看>>
轻轻松松更改NT超级用户密码 (转)
查看>>
给Win2000减减肥(转)
查看>>
Windows个性化之稀奇古怪三两式(转)
查看>>
nt的19个秘密武器(转)
查看>>
别让IE和Office泄露了你的秘密(转)
查看>>
让Windows2000和WindwosXP和平共处(转)
查看>>
将回收站变成保密站(转)
查看>>
制作Windows2000启动的“机密钥匙”(转)
查看>>
小心防范最易被黑客盯上的注册表位置(转)
查看>>
用注册表对系统进行全方位维护和管理(转)
查看>>
修改注册表阻止OfficeXP发送错误报告(转)
查看>>
不再费时费力两招快速定位注册表项(转)
查看>>
Win2K无盘终端网组建全攻略(6)(转)
查看>>