国产片侵犯亲女视频播放_亚洲精品二区_在线免费国产视频_欧美精品一区二区三区在线_少妇久久久_在线观看av不卡

服務器之家:專注于服務器技術及軟件下載分享
分類導航

PHP教程|ASP.NET教程|Java教程|ASP教程|編程技術|正則表達式|C/C++|IOS|C#|Swift|Android|VB|R語言|JavaScript|易語言|vb.net|

服務器之家 - 編程語言 - Java教程 - java 自己實現DataSource實現實例

java 自己實現DataSource實現實例

2020-10-05 12:18Java教程網 Java教程

這篇文章主要介紹了java 自己實現DataSource實現代碼的相關資料,需要的朋友可以參考下

java 自己實現DataSource實現代碼

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

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

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
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代碼 

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
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的動態代理來改寫MyDataSource:

Java代碼

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
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的動態代理生成的一個代理對象,該代理對象實現了Connection接口。

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

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

原文鏈接:http://xm-king.iteye.com/blog/800519

延伸 · 閱讀

精彩推薦
主站蜘蛛池模板: 免费av在线播放 | 日韩精品一区二区三区在线播放 | 亚洲情网站 | www.99精品 | 欧美 亚洲 一区 | 国产韩国精品一区二区三区 | 欧美在线综合 | 欧美日韩国产一区二区三区不卡 | 欧美成人精品一区二区三区 | 亚洲aⅴ天堂av在线电影软件 | 久久九九99 | 国产精品成人一区二区三区 | 日韩看片 | 国产精品一区二区在线观看 | 欧美精品综合 | 国产91对白叫床清晰播放 | 欧美大片免费高清观看 | 久久久影视| 开心久久婷婷综合中文字幕 | 国产精品久久久久久 | 午夜不卡视频 | 中文在线一区 | 精品美女久久久 | 最新国产在线 | 国产精品成人3p一区二区三区 | 成人夜色av | 国产精品国产精品国产专区不片 | 综合网激情 | 国产性猛交xxxx免费看久久 | av中文字幕在线 | 精品久久久久久国产 | 亚洲自拍偷拍精品视频 | 国产中文字幕在线 | 亚洲欧洲成人 | 国产精品欧美一区二区三区 | 久草免费在线视频 | 久久精品一区二区三区四区 | 精品国产一区二区三区四 | 欧美成人观看 | 91精品国产综合久久久久久丝袜 | 亚洲男人的天堂网站 |