享元模式(Flyweight)
享元模式的主要目的是实现对象的共享,即共享池,当系统中对象多的时候可以减少内存的开销,通常
与工厂模式一起使用。
FlyWeightFactory 负责创建和管理享元单元,当一个客户端请求时,工厂需要检查当前对象池中是否有
符合条件的对象,如果有,就返回已经存在的对象,如果没有,则创建一个新对象,FlyWeight 是超类。
一提到共享池,我们很容易联想到Java 里面的JDBC 连接池,想想每个连接的特点,我们不难总结出:
适用于作共享的一些个对象,他们有一些共有的属性,就拿数据库连接池来说,url、driverClassName、
username、password 及dbname,这些属性对于每个连接来说都是一样的,所以就适合用享元模式来
处理,建一个工厂类,将上述类似属性作为内部数据,其它的作为外部数据,在方法调用时,当做参数
传进来,这样就节省了空间,减少了实例的数量。
看个例子:
看下数据库连接池的代码:
public class ConnectionPool {
private Vector<Connection> pool;
/* 共有属性
* 数据库连接
**/
private String url = "jdbc:mysql://localhost:3306/test";
private String username = "root";
private String password = "adminadmin";
private String driverClassName = "com.mysql.jdbc.Driver";
private int poolSize = 100;
private static ConnectionPool instance = null;
Connection conn = null;
//构造方法,做一些初始化工作
private ConnectionPool(){
pool = new Vector<Connection>(poolSize);
for(int i = 0;i<poolSize;i++){
try{
Class.forName(driverClassName);
conn = DriverManager.getConnection(url,username,password);
pool.add(conn);
}catch(ClassNotFoundException | SQLException e){
e.printStackTrace();
}
}
}
//返回连接到的连接池
public synchronized void release(){
pool.add(conn);
}
//返回连接池中的一个数据库连接
public synchronized Connection getConnection(){
if(pool.size()>0){
Connection conn = pool.get(0);
pool.remove(conn);
return conn;
}else{
return null;
}
}
}
通过连接池的管理,实现了数据库连接的共享,不需要每一次都重新创建连接,节省了数据库重新创建
的开销,提升了系统的性能!这是享元模式一个很好的例子。