欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

java 自己實現DataSource實現實例

 更新時間:2017年05月15日 15:40:52   投稿:lqh  
這篇文章主要介紹了java 自己實現DataSource實現代碼的相關資料,需要的朋友可以參考下

java 自己實現DataSource實現代碼

  DataSource 對象所表示的物理數據源的連接。作為 DriverManager 工具的替代項。DataSource能提供最高性能的對數據庫的并發(fā)訪問,數據源技術是Java操作數據庫的一個很關鍵技術,流行的持久化框架都離不開數據源的應用。

         數據源提供了一種簡單獲取數據庫連接的方式,并能在內部通過一個池的機制來復用數據庫連接,這樣就大大減少了創(chuàng)建數據庫連接的次數,提高了系統性能。下面,我們自己動手實現個精簡的數據源,代碼如下:

public class MyDataSource { 
  private LinkedList<Connection> connectionPool = new LinkedList<Connection>(); 
 
  public MyDataSource() { 
    for (int i = 0; i < 10; i++) { 
      connectionPool.add(new MyConnection(creatConnection(),this)); 
    } 
  } 
  private Connection creatConnection() { 
    try { 
      return DriverManager.getConnection( 
          "jdbc:mysql://localhost:3306/test", "root", "root"); 
    } catch (SQLException e) { 
      // TODO Auto-generated catch block 
      throw new ExceptionInInitializerError(); 
    } 
  } 
   
  public Connection getConnection(){ 
    System.out.println(connectionPool.size()); 
    return connectionPool.removeFirst(); 
  } 
   
  public void freeConnection(Connection conn){ 
    System.out.println("DataSource Close Connection"); 
    connectionPool.addLast(conn); 
  } 
} 
 

Java代碼 

public class MyConnection implements Connection{ 
  private Connection connection; 
  private MyDataSource datasource; 
  public Connection getConnection() { 
    return connection; 
  } 
 
  public void setConnection(Connection connection) { 
    this.connection = connection; 
  } 
 
  public MyConnection(Connection realconnection,MyDataSource datasource){ 
    this.connection=realconnection; 
    this.datasource=datasource; 
  } 
   
  @Override 
  public void close() throws SQLException { 
    // TODO Auto-generated method stub 
    System.out.println("MyConnection Close"); 
    datasource.freeConnection(this); 
  } 
  ... 
} 

        我們通過DataSource獲得的Connection是經過包裹后的對象,這里應用到了代理模式。下面我們使用jdk的動態(tài)代理來改寫MyDataSource:

Java代碼

public class MyDataSource { 
  private LinkedList<Connection> connectionPool = new LinkedList<Connection>(); 
 
  public MyDataSource() { 
    for (int i = 0; i < 10; i++) { 
      connectionPool.add(GetProxy(creatConnection())); 
    } 
  } 
 
  private Connection GetProxy(final Connection connection) { 
    // TODO Auto-generated method stub 
    return (Connection)Proxy.newProxyInstance(this.getClass().getClassLoader(), new Class[]{Connection.class}, new InvocationHandler(){ 
      @Override 
      public Object invoke(Object proxy, Method method, Object[] args) 
          throws Throwable { 
        // TODO Auto-generated method stub 
        Object value; 
        if(method.getName().equalsIgnoreCase("close")){ 
          connectionPool.addLast((Connection)proxy); 
          System.out.println(connectionPool.size()); 
          return null; 
        }else{ 
          value=method.invoke(connection, args); 
        } 
        System.out.println(connectionPool.size()); 
        return value; 
      } 
       
    }); 
     
  } 
 
  private Connection creatConnection() { 
    try { 
      return DriverManager.getConnection( 
          "jdbc:mysql://localhost:3306/test", "root", "root"); 
    } catch (SQLException e) { 
      // TODO Auto-generated catch block 
      throw new ExceptionInInitializerError(); 
    } 
  } 
   
  public Connection getConnection(){ 
    System.out.println(connectionPool.size()); 
    return connectionPool.removeFirst(); 
  } 
   
  public void freeConnection(Connection conn){ 
    System.out.println("DataSource Close Connection"); 
    connectionPool.addLast(conn); 
  } 
} 

       通過這種方式獲得的Connection是通過jdk的動態(tài)代理生成的一個代理對象,該代理對象實現了Connection接口。

       以上兩種方式實現了我們自己的DataSource,在我們通過DataSource獲得的Connection對象的close方法都已經被改寫過了。在Connection對象調用close方法時,會將該Connection對象放入到緩存池中,而不是關閉對象。

       感謝閱讀,希望能幫助到大家,謝謝大家對本站的支持!

相關文章

  • Spring Boot 如何將 Word 轉換為 PDF

    Spring Boot 如何將 Word 轉換為 PDF

    這篇文章主要介紹了Spring Boot將Word轉換為 PDF,本文通過示例代碼給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2023-08-08
  • Java多線程并發(fā)FutureTask使用詳解

    Java多線程并發(fā)FutureTask使用詳解

    Java?的多線程機制本質上能夠完成兩件事情,異步計算和并發(fā),FutureTask?是基于?Runnable?實現的一個可取消的異步調用?API,本文給大家介紹Java?多線程并發(fā)FutureTask及基本使用,需要的朋友可以參考下
    2022-06-06
  • Java判斷變量是否為空問題的方法總結

    Java判斷變量是否為空問題的方法總結

    項目中經常遇到對象判空,下面這篇文章主要給大家介紹了關于Java判斷變量是否為空問題的方法,文中通過實例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友可以參考下
    2023-04-04
  • 詳解Java包裝類及自動裝箱拆箱

    詳解Java包裝類及自動裝箱拆箱

    這篇文章主要介紹了Java包裝類及自動裝箱拆箱,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2019-03-03
  • Spring Cloud 中@FeignClient注解中的contextId屬性詳解

    Spring Cloud 中@FeignClient注解中的contextId屬性詳解

    這篇文章主要介紹了Spring Cloud 中@FeignClient注解中的contextId屬性詳解,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2021-09-09
  • SpringMVC編程使用Controller接口實現控制器實例代碼

    SpringMVC編程使用Controller接口實現控制器實例代碼

    這篇文章主要介紹了SpringMVC編程使用Controller接口實現控制器實例代碼,具有一定參考價值,需要的朋友可以參考下。
    2017-11-11
  • Spring基于Aop實現事務管理流程詳細講解

    Spring基于Aop實現事務管理流程詳細講解

    這篇文章主要介紹了Spring基于Aop實現事務管理流程,事務管理對于企業(yè)應用來說是至關重要的,即使出現異常情況,它也可以保證數據的一致性,感興趣想要詳細了解可以參考下文
    2023-05-05
  • 非常全面的IReport的使用教程

    非常全面的IReport的使用教程

    iReport 是為JasperReports Library和JasperReports Server設計的報表可視化設計器。本教程給大家詳細介紹IReport的使用解析,感興趣的朋友一起看看吧
    2021-10-10
  • java NIO 詳解

    java NIO 詳解

    Java NIO(New IO)是從Java 1.4版本開始引入的一個新的IO API,可以替代標準的Java IO API。本系列教程將有助于你學習和理解Java NIO。
    2014-10-10
  • Java之CMS和G1垃圾回收過程的異同說明

    Java之CMS和G1垃圾回收過程的異同說明

    CMS垃圾回收器主要基于并發(fā)-清理算法,目的是減少停頓時間,通過四個主要階段進行垃圾回收:初始標記、并發(fā)標記、重新標記和并發(fā)清理,G1垃圾回收器采用標記-整理算法,是JDK9后的默認垃圾收集器,設計為全功能全代收集器
    2024-09-09

最新評論