亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 學院 > 開發設計 > 正文

java學習筆記—標準連接池的實現(27)

2019-11-14 23:40:08
字體:
來源:轉載
供稿:網友
java學習筆記—標準連接池的實現(27)

javax.sql.DataSource.

Java.sql.*

DataSource 接口由驅動程序供應商實現。共有三種類型的實現:

  1. 基本實現 - 生成標準的 Connection 對象 – 一個DataSource數據源中,只有一個Connection ,這個不是池管理。
  2. 連接池實現 [W1]- 生成自動參與連接池的 Connection 對象。
  3. 分布式事務實現 - 生成一個 Connection 對象,該對象可用于分布式事務,大多數情況下總是參與連接池。JTA.jar – SUN。

標準的連接池,要求:

1:實現dataSource接口。

2:聲明一個集合類用于管理多個連接。

3:必須要擁有一種能力,回收連接。

4:必須要實現一個方法,getConnection以獲取一個連接。

5:實現DataSource接口的類,一般不能擁有static池對象。List.

6:在一個程序中,要求只擁有一個DataSource實例就可以了。

以下是具體的實現:


import java.sql.Connection;import java.sql.DriverManager;import java.sql.SQLException;import java.util.LinkedList;import javax.sql.DataSource;/** * 標準的連接 */public class DBPool implements DataSource  {    //聲明一個池管理對象    PRivate LinkedList<Connection> pool = new LinkedList<Connection>();    //在初始化這個DataSourc的子類時在構造方法設置多個連接    public DBPool(){        try{            Class.forName("com.MySQL.jdbc.Driver");            String url = "jdbc:mysql:///db909?characterEncoding=UTf8";            for(int i=0;i<3;i++){                Connection con = DriverManager.getConnection(url,"root","1234");                //將生成的這個連接。放到pool                pool.add(con);            }        }catch(Exception e){            throw new RuntimeException(e.getMessage(),e);        }    }    public Connection getConnection() throws SQLException {        return pool.removeFirst();    }    ///其他的方法。不實現}

2:實現連接的回收

package cn.itcast.utils;import java.io.PrintWriter;import java.lang.reflect.InvocationHandler;import java.lang.reflect.Method;import java.lang.reflect.Proxy;import java.sql.Connection;import java.sql.DriverManager;import java.sql.SQLException;import java.util.LinkedList;import javax.sql.DataSource;/** * 標準的連接 */public class DBPool implements DataSource {    //聲明一個池管理對象    private LinkedList<Connection> pool = new LinkedList<Connection>();    //在初始化這個DataSourc的子類時在構造方法設置多個連接    public DBPool(){         try{            Class.forName("com.mysql.jdbc.Driver");            String url = "jdbc:mysql:///db909?characterEncoding=UTf8";            for(int i=0;i<3;i++){                final Connection con = DriverManager.getConnection(url,"root","1234");                Object proxyedConn =                        Proxy.newProxyInstance(DBPool.class.getClassLoader(),                                 new Class[]{Connection.class},                                new InvocationHandler() {                                    public Object invoke(Object proxyedConnection, Method method, Object[] args)                                            throws Throwable {                                        if(method.getName().equals("close")){                                            synchronized (pool) {                                                 pool.addLast((Connection) proxyedConnection);                                                pool.notify();                                            }                                            return  null;                                        }                                        //目標方法的返回值                                        Object returnValue=method.invoke(con, args);                                         return returnValue;                                    }                                });                pool.add((Connection) proxyedConn);            }        }catch(Exception e){            throw new RuntimeException(e.getMessage(),e);        }    }    public Connection getConnection() throws SQLException {         synchronized (pool) {            if(pool.size()==0){                try {                    pool.wait();                } catch (InterruptedException e) {                    e.printStackTrace();                }                return getConnection();            }            Connection con = pool.removeFirst();            System.err.println("siize:"+pool.size());            return con;        }    }}


發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
91精品中国老女人| 中文字幕精品一区久久久久| 亚洲精品日韩激情在线电影| 欧美日韩爱爱视频| 亚洲精品国产精品自产a区红杏吧| 欧美日韩午夜剧场| 欧美日韩国产一中文字不卡| 欧美成人免费全部观看天天性色| 97久久久久久| 97视频免费看| 亚洲第一视频网站| 日韩二区三区在线| 亚洲成人1234| 91精品视频在线| 国产成人欧美在线观看| 成人免费午夜电影| 亚洲一区二区福利| 国产91九色视频| 国产美女直播视频一区| 日韩中文有码在线视频| 一级做a爰片久久毛片美女图片| 精品美女永久免费视频| 久久久伊人欧美| 国产精品久久久久aaaa九色| 欧美激情中文字幕乱码免费| 国产视频999| 国产精品视频播放| 亚洲欧美在线一区二区| 国产视频自拍一区| 亚洲第一福利在线观看| 欧美日韩国产成人在线| 成人写真视频福利网| 国产精品视频内| 成人激情黄色网| 国产在线视频一区| 国产一级揄自揄精品视频| 欧美成人激情视频| 大桥未久av一区二区三区| 欧美在线视频导航| 国产精品pans私拍| 欧美色xxxx| 96精品视频在线| 色樱桃影院亚洲精品影院| 亚洲欧美日韩久久久久久| 久久久91精品国产一区不卡| 丝袜一区二区三区| 欧美性高潮床叫视频| 日韩免费av片在线观看| 日韩高清欧美高清| 热re99久久精品国产66热| 麻豆一区二区在线观看| 日韩精品999| 亚洲综合在线中文字幕| 成人av在线网址| 国产国语videosex另类| 欧美成人国产va精品日本一级| 久久久久久亚洲精品不卡| 欧美成年人视频网站| 日日骚久久av| 日韩欧美国产黄色| 欧美性在线视频| 中文字幕av一区二区| 亚洲欧美激情另类校园| 在线观看精品国产视频| 亚洲综合色av| 米奇精品一区二区三区在线观看| 久久免费国产视频| 国产女同一区二区| 久久99国产精品久久久久久久久| 98视频在线噜噜噜国产| 91影视免费在线观看| 色妞在线综合亚洲欧美| 国产成人精品久久二区二区| 91高清在线免费观看| 亚洲精品欧美一区二区三区| 亚洲综合社区网| 欧美午夜无遮挡| 国产suv精品一区二区三区88区| 日本成人在线视频网址| 欧美激情videoshd| 色噜噜国产精品视频一区二区| 久久精品在线视频| 国产成人精品一区二区| 久久精品国产亚洲精品2020| www欧美xxxx| 欧美亚洲免费电影| 亚洲一区久久久| 欧美在线中文字幕| 久久久久久久久亚洲| 91亚洲精品久久久| 欧美激情综合亚洲一二区| 国产精品小说在线| 久热在线中文字幕色999舞| 成人黄色av免费在线观看| 欧美性生交大片免费| 日韩免费中文字幕| 亚洲综合中文字幕在线观看| 91免费精品国偷自产在线| 国产成人精品免费久久久久| 国产色婷婷国产综合在线理论片a| 亚洲欧美日韩天堂| 在线日韩av观看| 中文字幕日韩有码| 欧美精品videossex性护士| 日韩电影中文字幕| 日韩h在线观看| 成人黄色激情网| 成人免费激情视频| 狠狠色狠色综合曰曰| 亚洲黄一区二区| 一区二区三区久久精品| 岛国av在线不卡| 午夜精品美女自拍福到在线| 欧美日韩激情视频8区| 欧美激情精品久久久久久蜜臀| 欧美日韩激情美女| 亚洲一区免费网站| 日韩精品免费在线| 午夜欧美大片免费观看| 国产精品美女免费| 中文日韩电影网站| 国产精品久久久久久久电影| 欧美性在线视频| 国产精品一区二区女厕厕| 欧美裸身视频免费观看| 欧美成人亚洲成人日韩成人| 日韩精品免费在线视频观看| 欧美三级xxx| 国产欧美一区二区三区四区| 久久久久久久激情视频| 精品丝袜一区二区三区| …久久精品99久久香蕉国产| 国语自产精品视频在免费| 国产一区二区三区三区在线观看| 91免费看片在线| 亚洲国产精品国自产拍av秋霞| 久久影视电视剧免费网站| 亚洲综合大片69999| 最新91在线视频| 日韩精品在线观看视频| 欧美日韩激情视频| 国产经典一区二区| 夜色77av精品影院| 亚洲精品福利在线| 亚洲国产一区二区三区在线观看| 欧美激情综合色综合啪啪五月| 亚洲成人在线视频播放| 日韩三级影视基地| 日韩av日韩在线观看| 国产视频自拍一区| 成人免费看黄网站| 91av在线影院| 国产欧美一区二区三区在线看| 亚洲欧美在线免费观看| 国产日韩精品综合网站| 91精品国产乱码久久久久久蜜臀| 亚洲精品成人av| 国产精品r级在线| 亚洲精选一区二区| 国产精品视频内| 久久这里有精品视频| 国产午夜精品全部视频播放| 久久影视电视剧免费网站清宫辞电视| 人人爽久久涩噜噜噜网站|