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

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

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

    eric-1001c

      BlogJava :: 首頁 :: 新隨筆 :: 聯系 :: 聚合  :: 管理 ::
      3 隨筆 :: 45 文章 :: 12 評論 :: 0 Trackbacks

    在利用Hibernate開發DAO模塊時,我們和Session打的交道最多,所以如何合理的管理Session,避免Session的頻繁創建 和銷毀,對于提高系統的性能來說是非常重要的,以往是通過eclipse的插件來自動完成這些代碼的,當然效果是不錯的,但是總是覺得不爽(沒有讀懂那些 冗長的代碼),所以現在打算自己實現Session管理的代碼。

    我們知道Session是由SessionFactory負責創建的,而SessionFactory的實現是線程安全的,多個并發的 線程可以同時訪問一個SessionFactory并從中獲取Session實例,那么Session是否是線程安全的呢?很遺憾,答案是否定的。 Session中包含了數據庫操作相關的狀態信息,那么說如果多個線程同時使用一個Session實例進行CRUD,就很有可能導致數據存取的混亂,你能 夠想像那些你根本不能預測執行順序的線程對你的一條記錄進行操作的情形嗎?

    在Session的眾多管理方案中,我們今天來認識一種名ThreadLocal模式的解決方案。

    早在Java1.2推出之時,Java平臺中就引入了一個新的支持:java.lang.ThreadLocal,給我們在編寫多線程程序 時提供了一種新的選擇。ThreadLocal是什么呢?其實ThreadLocal并非是一個線程的本地實現版本,它并不是一個Thread,而是 thread local variable(線程局部變量)。也許把它命名為ThreadLocalVar更加合適。線程局部變量(ThreadLocal)其實的功用非常簡單, 就是為每一個使用某變量的線程都提供一個該變量值的副本,是每一個線程都可以獨立地改變自己的副本,而不會和其它線程的副本沖突。從線程的角度看,就好像 每一個線程都完全擁有一個該變量。

    ThreadLocal是如何做到為每一個線程維護變量的副本的呢?其實實現的思路很簡單,在ThreadLocal類中有一個Map,用于存儲每一個線程的變量的副本。比如下面的示例實現(為了簡單,沒有考慮集合的泛型):

    public  class  ThreadLocal  {
    private Map values = Collections.synchronizedMap(new HashMap());
    public Object get() {
    Thread currentThread = Thread.currentThread();
    Object result = values.get(currentThread);
    if(result == null&&!values.containsKey(currentThread)) {
    result = initialValue();
    values.put(currentThread, result);
    }
    return result;
    }
    public void set(Object newValue) {
    values.put(Thread.currentThread(), newValue);
    }
    public Object initialValue() {
    return null;
    }
    }

    那麼具體如何利用ThreadLocal來管理Session呢?Hibernate官方文檔手冊的示例之中,提供了一個通過ThreadLocal維護Session的好榜樣:

    public  class  HibernateUtil  {
    public static final SessionFactory sessionFactory;
    static {
    try {
    sessionFactory = new Configuration().configure().buildSessionFactory();
    } catch (Throwable ex) {
    throw new ExceptionInInitializerError(ex);
    }
    }
    public static final ThreadLocal<Session>session=new ThreadLocal<Session>();
    public static Session currentSession() throws HibernateException {
    Session s = session.get();
    if(s == null) {
    s = sessionFactory.openSession();
    session.set(s);
    }
    return s;
    }
    public static void closeSession() throws HibernateException {
    Session s = session.get();
    if(s != null) {
    s.close();
    }
    session.set(null);
    }
    }

    只要借助上面的工具類獲取Session實例,我們就可以實現線程范圍內的Session共享,從而避免了線程中頻繁的創建和銷毀Session實 例。當然,不要忘記在用完后關閉Session。寫到這里,想再多說一些,也許大多數時候我們的DAO并不會涉及到多線程的情形,比如我們不會將DAO的 代碼寫在Servlet之中,那樣不是良好的設計,我自己通常會在service層的代碼里訪問DAO的方法。但是我還是建議采用以上的工具類來管理 Session,畢竟我們不能僅僅考慮今天為自己做什么,還應該考慮明天為自己做什么!

    posted on 2008-03-13 17:04 Eric-1001c 閱讀(295) 評論(0)  編輯  收藏 所屬分類: Hibernate
    主站蜘蛛池模板: 日日麻批免费40分钟日本的| 亚洲成人在线网站| 免费人成在线观看69式小视频| 黄色一级视频免费| ASS亚洲熟妇毛茸茸PICS| 亚洲s色大片在线观看| 免费人成视频在线观看视频| 欧美男同gv免费网站观看| 色欲色香天天天综合网站免费| 国产免费A∨在线播放| 国产亚洲视频在线观看网址| 亚洲乱码一二三四区乱码| 337p日本欧洲亚洲大胆精品555588| 亚洲综合AV在线在线播放| 亚洲最大的成人网站| 亚洲人成网站影音先锋播放| 亚洲乳大丰满中文字幕| 亚洲av日韩av欧v在线天堂| 免费毛片在线播放| 18禁超污无遮挡无码免费网站国产| 亚洲综合免费视频| 最近2022中文字幕免费视频| 暖暖日本免费中文字幕| 精品国产麻豆免费人成网站| 拍拍拍无挡视频免费观看1000| aa级女人大片喷水视频免费| AAAAA级少妇高潮大片免费看| 一区二区三区免费精品视频| 一进一出60分钟免费视频| a一级毛片免费高清在线| 一个人看的在线免费视频| 一个人看的免费视频www在线高清动漫| 国产成人综合久久精品亚洲| 最新亚洲人成无码网站| 国产精品亚洲精品爽爽| 黄色a级片免费看| xxxxxx日本处大片免费看| 男女一边摸一边做爽的免费视频| 中文字幕免费在线看电影大全| 中国性猛交xxxxx免费看| 国产白丝无码免费视频|