|  
 从一个ConnectionPool的实现看design pattern的运用 (四) 
好了,同学们,大家对上回的“李四猜想”有没有结果呀? 
  
我们的口号是?。。。。。。 
“没有蛀牙”! 
  
No! 是“用户至上”! 
  
既然用户有容易忘的可能,那就证明我们的工作做得不好。我们为什么非要用户做他们做不好或容易弄错的事呢? 
  
好吧,让我们知错就改: 
  
public interface ConnectionMan extends PooledConnection.Pool{ 
//在这个interface里,我们不再要求程序员必须封装Connection, 他们只需要直接返回Connection对象。 实际上,程序员可以完全忘记封装这码事。 
//我们将对返回的对象进行封装。 
    Connection getConnection()throws SQLException; 
    void clear(); 
    void closeConnection(Connection conn); 
} 
  
//然后,我们用一下的decorator类对返回值进行封装 
  
public class ConnectionMan2ConnectionPool implements ConnectionPool{ 
    public final Connection getConnection()throws SQLException{ 
            return PooledConnection.decorate(man.getConnection(), man); 
    } 
    public final void clear(){ 
                man.clear(); 
    } 
    private final ConnectionMan man; 
    private ConnectionMan2ConnectionPool(ConnectionMan man){ 
                this.man = man; 
    } 
    public static ConnectionPool decorate(ConnectionMan man){ 
            return new ConnectionMan2ConnectionPool(man); 
    } 
} 
  
这样,程序员只需要实现一个辅助interface ConnectionMan. 完全不要考虑封装Connection的事。然后再用我们的ConnectionMan2ConnectionPool类把它转换成ConnectionPool, 交给ConnectionPool的用户使用。耶! 
  
  
“那万一李四忘了用ConnectionMan2ConnectionPool转换怎么办?” 
  
呵呵,别忘了,编译器不是吃素的。用户期待ConnectionPool, 而李四只有ConnectionMan, 他想不转换也不行啊! 
  
什么?今天的家庭作业? 
啊,让你们家长写表扬信给ajoo老师。:) 
  
  
  
  
  
  
  
玩笑。如果那位能发现进一步refactor的地方,欢迎指出!  
 
  |