请问下关于类似将连接还给连接池的功能。

我有个方法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的实现。