<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 閱讀(303) 評論(0)  編輯  收藏 所屬分類: Hibernate
    主站蜘蛛池模板: a毛片免费全部在线播放**| 亚洲情A成黄在线观看动漫软件| 老湿机一区午夜精品免费福利| 成人黄18免费视频| 亚洲人成综合网站7777香蕉| 免费毛片在线看片免费丝瓜视频| 亚洲视频一区二区三区四区| 亚洲熟妇丰满多毛XXXX| 一区二区三区在线免费观看视频 | 国产在线观看免费视频软件| 亚洲欧洲自拍拍偷午夜色无码| 97国免费在线视频| 亚洲AV成人无码久久精品老人| 久久久久久AV无码免费网站| 亚洲黄色免费网址| 歪歪漫画在线观看官网免费阅读| 亚洲欧美乱色情图片| 内射无码专区久久亚洲| 国产亚洲av片在线观看播放| 久久aa毛片免费播放嗯啊| 亚洲老熟女@TubeumTV| 91在线品视觉盛宴免费| 立即播放免费毛片一级| 国产亚洲精久久久久久无码AV| 久久久久久AV无码免费网站| 亚洲日韩精品无码专区加勒比☆| 国产精品国产午夜免费福利看| 午夜肉伦伦影院久久精品免费看国产一区二区三区 | 久久久免费的精品| 久久精品国产亚洲av麻豆图片| 日本不卡在线观看免费v| 亚洲免费在线观看| 亚洲精品在线播放| 免费人成视网站在线观看不卡| 三上悠亚电影全集免费| 亚洲国产日韩在线成人蜜芽| 免费大黄网站在线观看| 最近中文字幕mv免费高清视频8| 亚洲成av人片在线天堂无| 亚洲欧洲∨国产一区二区三区 | 免费国产精品视频|