我有个方法getConnect()这个方法是获取连接的;
假如说他用Connection conn=getConnect();获取连接,在返回连接池的时候我提供了一个方法,close(Connection conn);这个方法是将连接返回给连接池,
但是假如他这样 Connection conn=getConnect();
close(conn);连接是返回了但是那个他的 conn变量还可以用,按理说连接返回的时候他使用的连接conn不应该可以使用,但是我不知道该怎么样的方法让他接受的变量conn为NULL?让他不能使用返回的连接。
通常你不能动使用者那边的代码。这样也不合乎常理。
我的建议是,用代理模式。
真正的Connection藏在代理类里面,连接池也是对真正Connection的连接。类似下面这样:
[code="java"]
public class MyConnection {//Connection代理类
/**
* 真正的Connection。
*/
private Connection conn;
/**
* 分配给某个用户时,把真正的Connection设进来。
*
* @param conn
*/
void setConn(Connection conn) {
this.conn = conn;
}
/**
* 关闭时,把Connection设成null。
*/
void close() {
this.conn = null;
}
Connection getConn() {
return conn;
}
// ... 代理其他Connection方法。
}
[/code]
这样一旦使用者,关闭Connection后又企图再次使用时,你就可以检查真正的connection是否为null,然后抛异常给他。
[code="java"]
public class ConnectionPool{
private LinkedList<Connection> connList;
public Connection getConnection(){
if(connList.isEmpty()){
return null;
}else{
return connList.remove(0);
}
}
public void releaseConnection(Connection conn) throws SQLException{
if(!conn.isClosed()){
conn.close();
}
Connection release = conn;
conn = null;
connList.add(release);
}
}
[/code]
客户端看到的Connection其实是个代理类。
线程池中放的是正真的Connection。暂且叫PoolConnection。
这个Connection里面有个字段表示为close
使用这个Connection方法前加判断checkClose()。
如果close则抛出异常 Connection is close .
你可以看看dbcp中
org.apache.commons.dbcp.cpdsadapter.ConnectionImpl的实现。