<rt id="bn8ez"></rt>
<label id="bn8ez"></label>

  • <span id="bn8ez"></span>

    <label id="bn8ez"><meter id="bn8ez"></meter></label>

    沙漠中的魚

    欲上天堂,先下地獄
    posts - 0, comments - 56, trackbacks - 0, articles - 119
      BlogJava :: 首頁 ::  :: 聯系 :: 聚合  :: 管理

    ConnectionPool.java:

    public interface ConnectionPool{
        Connection getConnection()
        
    throws test.res.ResourceNotAvailableException, SQLException;
        Connection getConnection(
    long timeout)
        
    throws test.res.ResourceTimeOutException, SQLException;
        
    void clear();
    }

    ConnectionHome.java:

    public interface ConnectionHome{
     
    void releaseConnection(Connection conn);
    }

    ConnectionPooling.java:

    public interface ConnectionPooling extends ConnectionHome{
        Connection getConnection()
        
    throws test.res.ResourceNotAvailableException, SQLException;
        
        Connection getConnection(
    long timeout)
        
    throws test.res.ResourceTimeOutException, SQLException;
        
    void clear();
        
    void releaseConnection(Connection conn);
    }
    ConnectionFactory.java:
    public interface ConnectionFactory{
     
    public Connection createConnection()throws SQLException;
    }

    PooledConnection.java: (for Connection in Java 1.1.8)

    public final class PooledConnection implements Connection{
        
    private interface ConnectionState{
            ConnectionState close();
            
    boolean isClosed();
            Connection getOpenConnection()
            
    throws SQLException;
        }

        
    private static class ClosedConnection implements ConnectionState{
            
    public final ConnectionState close(){return this;}
            
    public final Connection getOpenConnection()
            
    throws SQLException{
                
    throw new SQLException("Connection closed");
            }

            
    public final boolean isClosed(){return true;}
            
    private ClosedConnection(){}
            
    private static final ConnectionState _instance = new ClosedConnection();
            
    static ConnectionState instance(Connection conn, ConnectionHome home){return _instance;}
        }

        
        
    private static class OpenConnection implements ConnectionState{
         
    private final ConnectionHome home;
            
    private final Connection conn;
            
    public final ConnectionState close(){
                    home.releaseConnection(conn);
                    
    return ClosedConnection.instance(conn, home);
            }

            
    public final Connection getOpenConnection()
            
    {return conn;}
            
    public final boolean isClosed(){return false;}
            OpenConnection(Connection conn, ConnectionHome home)
    {
             
    this.conn = conn; this.home = home;
            }

            
    static ConnectionState instance(Connection conn, ConnectionHome home){
             
    return new OpenConnection(conn, home);
            }

        }

        
    private ConnectionState state;
        
    public static Connection decorate(Connection conn, ConnectionHome home)
        
    throws SQLException{
         
    return new PooledConnection(conn, home);
        }

        
        
    private PooledConnection(Connection conn, ConnectionHome home)
        
    throws SQLException{
            
    if(conn.isClosed()){
                state 
    = ClosedConnection.instance(conn, home);
            }

            
    else{
                state 
    = OpenConnection.instance(conn, home);
            }

        }
           
        
    public final boolean isClosed(){
            
    return state.isClosed();
        }


        
    public final void close(){
            state 
    = state.close();
        }

        
    protected void finalize(){
          close();
        }

        
    private final Connection getOpenConnection()
        
    throws SQLException
        
    {return state.getOpenConnection();}
        
    /*****then, delegate all the other methods****/
        
    public final Statement createStatement()
        
    throws SQLException{
            
    return getOpenConnection().createStatement();
        }

       
        
    //.
        public final void clearWarnings()throws SQLException{
            getOpenConnection().clearWarnings();
        }

          
     
        
    public final void commit()throws SQLException{
            getOpenConnection().commit();
        }


        
    /*
        public final Statement createStatement(int resultSetType, 
            int resultSetConcurrency)
        throws SQLException{
            return getOpenConnection().createStatement(resultSetType, resultSetConcurrency);
        }
    */

        
        
    /*
        public final Statement createStatement(int resultSetType, 
            int resultSetConcurrency, int resultSetHoldability)
        throws SQLException{
            return getOpenConnection().createStatement(resultSetType, 
                resultSetConcurrency, resultSetHoldability);
        }
    */

        
        
        
    public final boolean getAutoCommit()throws SQLException{
            
    return getOpenConnection().getAutoCommit();
        }

        
    public final String getCatalog()throws SQLException{
            
    return getOpenConnection().getCatalog();
        }

        
    /*
        public final int getHoldability()throws SQLException{
            return getOpenConnection().getHoldability();
        }
    */

          
        
    public final DatabaseMetaData getMetaData()throws SQLException{
            
    return getOpenConnection().getMetaData();
        }

        
    public final int getTransactionIsolation()throws SQLException{
            
    return getOpenConnection().getTransactionIsolation();
        }

        
    /*
        public final Map getTypeMap()throws SQLException{
            return getOpenConnection().getTypeMap();
        }
    */

        
    public final SQLWarning getWarnings()throws SQLException{
            
    return getOpenConnection().getWarnings();
        }
     

        
    public final boolean isReadOnly()throws SQLException{
            
    return getOpenConnection().isReadOnly();
        }

        
    public final String nativeSQL(String sql)throws SQLException{
            
    return getOpenConnection().nativeSQL(sql);
        }

        
    public final CallableStatement prepareCall(String sql)throws SQLException{
            
    return getOpenConnection().prepareCall(sql);
        }

        
    /*
        public final CallableStatement prepareCall(String sql, 
            int resultSetType, int resultSetConcurrency)
        throws SQLException{
            return getOpenConnection().prepareCall(sql, resultSetType, resultSetConcurrency);
        }
          
        public final CallableStatement prepareCall(String sql, 
            int resultSetType, int resultSetConcurrency, int resultSetHoldability)
        throws SQLException{
            return getOpenConnection().prepareCall(sql, resultSetType, 
                resultSetConcurrency, resultSetHoldability);
        }
    */

          
        
    public final PreparedStatement prepareStatement(String sql)
        
    throws SQLException{
            
    return getOpenConnection().prepareStatement(sql);
        }

        
    /*
        public final PreparedStatement prepareStatement(String sql, int autoGeneratedKeys)
        throws SQLException{
            return getOpenConnection().prepareStatement(sql, autoGeneratedKeys);
        }

        public final PreparedStatement prepareStatement(String sql, int[] columnIndexes)
        throws SQLException{
            return getOpenConnection().prepareStatement(sql, columnIndexes);
        }
        
        public final PreparedStatement prepareStatement(String sql, 
            int resultSetType, int resultSetConcurrency)
        throws SQLException{
            return getOpenConnection().prepareStatement(sql, 
                resultSetType, resultSetConcurrency);
        }
          
        public final PreparedStatement prepareStatement(String sql, 
            int resultSetType, int resultSetConcurrency, int resultSetHoldability)
        throws SQLException{
            return getOpenConnection().prepareStatement(sql, 
                resultSetType, resultSetConcurrency, resultSetHoldability);
        }
          
        public final PreparedStatement prepareStatement(String sql, 
            String[] columnNames)
        throws SQLException{
            return getOpenConnection().prepareStatement(sql, columnNames);
        }
          
        public final void releaseSavepoint(Savepoint savepoint)throws SQLException{
            getOpenConnection().releaseSavepoint(savepoint);
        }
    */

        
    public final void rollback()throws SQLException{
            getOpenConnection().rollback();
        }

        
    /*
        public final void rollback(Savepoint savepoint)
        throws SQLException{
            getOpenConnection().rollback(savepoint);
        }
    */

          
        
    public final void setAutoCommit(boolean autoCommit)
        
    throws SQLException{
            getOpenConnection().setAutoCommit(autoCommit);
        }

          
        
    public final void setCatalog(String catalog)
        
    throws SQLException{
            getOpenConnection().setCatalog(catalog);
        }

        
    /* 
        public final void setHoldability(int holdability)
        throws SQLException{
            getOpenConnection().setHoldability(holdability);
        }
    */
             
        
    public final void setReadOnly(boolean readOnly)
        
    throws SQLException{
            getOpenConnection().setReadOnly(readOnly);
        }

        
    /*
        public final Savepoint setSavepoint()throws SQLException{
            return getOpenConnection().setSavepoint();
        }
          
        public final Savepoint setSavepoint(String name)
        throws SQLException{
            return getOpenConnection().setSavepoint(name);
        }
    */

          
        
    public final void setTransactionIsolation(int level)
        
    throws SQLException{
            getOpenConnection().setTransactionIsolation(level);
        }

        
    /*public final void setTypeMap(Map map)throws SQLException{
            getOpenConnection().setTypeMap(map);
        }
    */


        
    /*************************************************************************************************/
        

    }

    ConnectionPooling2Pool.java:

    public class ConnectionPooling2Pool implements ConnectionPool{
        
    public final Connection getConnection()
        
    throws test.res.ResourceNotAvailableException, SQLException{
         
    return PooledConnection.decorate(pooling.getConnection(), pooling);
        }

        
    public final Connection getConnection(long timeout)
        
    throws test.res.ResourceTimeOutException, SQLException{
         
    return PooledConnection.decorate(pooling.getConnection(timeout), pooling);
        }

        
    public final void clear(){
         pooling.clear();
        }

        
    private final ConnectionPooling pooling;
        
    private ConnectionPooling2Pool(ConnectionPooling pooling){
         
    this.pooling = pooling;
        }

        
    public static ConnectionPool decorate(ConnectionPooling pooling){
         
    return new ConnectionPooling2Pool(pooling);
        }

    }

    ConnectionPoolingImpl.java: (a simple implementation of ConnectionMan)

    public class ConnectionPoolingImpl implements ConnectionPooling
    {
        
    private int client=0;
        
    private final Vector freeConn = new Vector();
        
    private final int maxConn;
        
    private final ConnectionFactory factory;

        
    static public ConnectionPooling instance(ConnectionFactory factory, int max){
         
    return new ConnectionPoolingImpl(factory, max);
        }

        
        
    private ConnectionPoolingImpl(ConnectionFactory factory, int max){
         
    this.factory = factory;
         
    this.maxConn = max;
        }


        
    public final synchronized void releaseConnection(Connection conn)
        
    {
            freeConn.addElement(conn);
            client
    --;
            notify();
        }


        
    public final synchronized Connection getConnection()
        
    throws ResourceNotAvailableException, SQLException
        
    {
            Connection conn 
    = null;
            
    if(freeConn.size() > 0)
            
    {
                conn 
    = (Connection)freeConn.lastElement();
                freeConn.removeElementAt(freeConn.size()
    -1);
            }

            
    else if(client < maxConn)
            
    {
                conn 
    = factory.createConnection();
            }

            
    if(conn != null)
            
    {
                client
    ++;
                
    return conn;
            }

            
    else
            
    {
                
    throw new ResourceNotAvailableException();
            }

        }


        
    public final synchronized Connection getConnection(long timeout)
        
    throws ResourceTimeOutException, SQLException
        
    {
            
    for(long startTime = new java.util.Date().getTime();;)
            
    {
                
    try
                
    {
                    
    return getConnection();
                }

                
    catch(ResourceNotAvailableException e1)
                
    {
                    
    try
                    
    {
                        wait(timeout);
                    }

                    
    catch(InterruptedException e2)
                    
    {}
                    
    if((new java.util.Date().getTime() - startTime) >= timeout)
                    
    {
                        
    throw new ResourceTimeOutException();
                    }

                }

            }

        }



        
    public final synchronized int getfreeconn(){
            
    return freeConn.size();
        }

        
    public final int getmaxConn(){
            
    return maxConn;
        }

        
    public final synchronized int getclient(){
            
    return client;
        }

        
    public final synchronized void setclient(){
            client
    =0;
        }


        
    public final synchronized void clear(){
      closeAll();
            freeConn.removeAllElements();
        }

        
    private final void closeAll(){
            
    for(int i=0; i<freeConn.size();i++)
            
    {
                
    final Connection conn = (Connection)freeConn.elementAt(i);
                
    try{
                    conn.close();
                }

                
    catch(SQLException sqlException){}
            }

        }

        
    protected void finalize(){
         closeAll();
        }
        
    }

    ConnectionFactoryImpl.java:

    public class ConnectionFactoryImpl
    {
        
    private ConnectionFactoryImpl(){}
        
    static public ConnectionFactory instance(final String driver, final String url, 
         
    final String user, final String pwd)
        
    throws SQLException, ClassNotFoundException{
      
    final Class driverClass = Class.forName(driver);
      
    return new ConnectionFactory(){
       
    private final Class keeper = driverClass;
       
    public final Connection createConnection()
       
    throws SQLException{
        
    return DriverManager.getConnection(url,user,pwd);
       }

      }
    ;
        }

        
    static public ConnectionFactory instance(final String driver, final String url)
        
    throws SQLException, ClassNotFoundException{
      
    final Class driverClass = Class.forName(driver);
      
    return new ConnectionFactory(){
       
    private final Class keeper = driverClass;
       
    public final Connection createConnection()
       
    throws SQLException{
        
    return DriverManager.getConnection(url);
       }

      }
    ;
     }
      
    }

    TestConnectionPool.java:

    public class TestConnectionPool{
     
    public static void test(String driver, String url, String user, String pwd)
     
    throws java.sql.SQLException, test.res.ResourceNotAvailableException, test.res.ResourceTimeOutException, ClassNotFoundException{
      
    final ConnectionPool pool = ConnectionPooling2Pool.decorate(
       ConnectionPoolingImpl.instance(
        ConnectionFactoryImpl.instance(driver, url, user, pwd),
        
    1000)
       );
     }

    }


    ResourceNotAvailableException.java:

    public class ResourceNotAvailableException extends RuntimeException{
     
    public ResourceNotAvailableException(String msg){super(msg);}
     
    public ResourceNotAvailableException(){}
    }


    ResourceTimeOutException.java:

    public class ResourceTimeOutException extends Exception{
     
    public ResourceTimeOutException(String msg){super(msg);}
     
    public ResourceTimeOutException(){}
    }

     

     

    主站蜘蛛池模板: jyzzjyzz国产免费观看| 久久久久噜噜噜亚洲熟女综合| 日韩av无码久久精品免费| 中国毛片免费观看| 国产精品免费在线播放| aa级女人大片喷水视频免费| 国产精品九九久久免费视频| 国产精品1024在线永久免费| GOGOGO免费观看国语| 丁香花在线视频观看免费| A级毛片高清免费视频在线播放| 中文字幕在线免费观看视频| a级片免费在线播放| 在线观看片免费人成视频无码| 日韩精品无码免费一区二区三区| 亚洲AV成人片色在线观看高潮| 国产精品亚洲精品青青青| 亚洲无限乱码一二三四区| 亚洲第一区视频在线观看| 亚洲综合久久1区2区3区| 亚洲人成高清在线播放| 久久国产亚洲精品| 在线91精品亚洲网站精品成人| aa午夜免费剧场| 国产精品免费观看调教网| 亚洲一区二区免费视频| 免费被黄网站在观看| 亚洲国产精品人人做人人爽| 亚洲精品无码成人AAA片| 久久精品国产亚洲AV高清热| 中文字幕亚洲精品无码| 无人视频免费观看免费视频 | 国产一区二区三区免费看| 伊人久久亚洲综合影院| 亚洲人成77777在线播放网站| 亚洲国产日韩一区高清在线| 国产亚洲国产bv网站在线| 成人国产网站v片免费观看| 久久成人a毛片免费观看网站| 免费av欧美国产在钱| 亚洲国产精品无码久久久久久曰|