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

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

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

    2009年4月11日

         摘要:   以下是本人在學習過程中做的一點點小小的總結,在這里留個副本! 現有代碼存在的問題: 為了解決每個業務模塊對應一個Servlet,Servlet過多的問題 解決辦法: 使用一個新的Servlet,匯總了所有的業務模塊Servlet,增加邏輯判斷,具體調用哪個業務Servlet public class ServletAction extends HttpServlet {...  閱讀全文
    posted @ 2009-04-11 21:48 西西里 閱讀(388) | 評論 (0)編輯 收藏

    2009年4月2日

    public class UserService {
        private UserService userService = null;

        private UserService() {}

        public static UserService getInstance() {
            if(userService == null) {
                synchronized(UserService.class) {
                    if(userService == null) {userService = new UserService();}
                }
            }
        return userService;
        }
    }
    posted @ 2009-04-02 21:46 西西里 閱讀(2344) | 評論 (12)編輯 收藏
     
     

    首先,當DAOCatchSQL異常,應該讓相應的事務回滾,并繼續拋出該異常

    conn.rollback();

    throw e;

    在方法聲明時throws這個異常;

    第二,在Service層調用到Dao層時,try catch這個異常,在catch住中把它處理為RuntimeException異常;

    處理過程是:自定義一個繼承自RuntimeException的異常類AppRuntimeException;

    catch(){

    new AppRuntimeException();

    }

    第三,在Servlet中使用配置文件web.xml注冊這個Exception,或者注冊為RuntimeException,調用Service時,如果發生這個異常,則會跳轉到相關的友好的面向用戶的錯誤頁面;

    注意:如果頁面未轉向,則可能是反射過程中拋出的其他異常截獲了我們自定義的這個RuntimeException,我們可以在這個異常中做出處理,讓它轉換為我們自定義的RuntimeException;

    第四,以上我們只是簡單的處理了異常,一般正常的與業務相關的異常;

    posted @ 2009-04-02 14:01 西西里 閱讀(1376) | 評論 (3)編輯 收藏

    2009年4月1日

     

           為了解決一個事務的多個數據模型使用多個Connection的情況,首先想到的是在執行每個原子級數據模型的操作的時候直接在方法的參數中傳進來一個Connection,下一個操作也把這個同一個Connection傳進來,但是這樣帶來的問題有兩個,一是,設計問題,針對數據庫的操作DAO的方法中的參數一般都應該是針對數據庫查詢的查詢條件,把Connection放在這里作為參數顯然不合適;第二,Connection作為多個數據模型操作的共享,只在最后一個操作中才被關閉,這對于如果只有單個操作的事務執行時,Connection將不會被關閉。    
       
        為了解決這些問題,需要有一個專門生產Connection的類,供DAO層各方法調用,但是幾個方法如果是同一事務時,他們拿到的Connection應該是同一個;
        
       由此,生產Connection的類,有兩個方法,一是生產Connecton,放到一個容器中,即set方法,二是得到Conneciton,即get方法;

         當同一事務的多個方法調用時,拿到同一個容器中的Connection即可保證他們拿到的是同一個Connection對象;

         為了保證拿到的是同一個容器,使用類級別的變量,static Hashtable;

          采取static類變量的方式,解決了以上引起的設計問題?    
       
        因為static的方法是位于方法區中的,多個線程共享,所以又引發了線程不安全的問題;
        
       
        所以使用API中的ThreadLocal類型的變量,使得多個線程各自擁有自己的一個容器,從而解決了線程不安全的問題。

    posted @ 2009-04-01 15:30 西西里 閱讀(1912) | 評論 (4)編輯 收藏
    僅列出標題  
     
    主站蜘蛛池模板: 亚洲乱码在线观看| j8又粗又长又硬又爽免费视频 | 日韩a毛片免费观看| 亚洲香蕉网久久综合影视| 人人揉揉香蕉大免费不卡| 亚洲不卡视频在线观看| www.91亚洲| 十八禁无码免费网站| 亚洲一区AV无码少妇电影| 国产精品亚洲二区在线观看 | 亚洲精品第一综合99久久| 亚洲国产小视频精品久久久三级| 四虎影视成人永久免费观看视频| 亚洲国产美女视频| 亚洲日韩在线观看免费视频| 99爱在线精品免费观看| 一级特级女人18毛片免费视频 | 成人自慰女黄网站免费大全| 亚洲一区二区免费视频| 在线日韩日本国产亚洲| 午夜宅男在线永久免费观看网| 好猛好深好爽好硬免费视频| 亚洲最大的成人网| 亚洲成人在线网站| 大胆亚洲人体视频| 成人影片麻豆国产影片免费观看 | 最新猫咪www免费人成| 韩日电影在线播放免费版| 2020久久精品亚洲热综合一本| 黑人大战亚洲人精品一区| 四虎影院在线免费播放| 久久免费看少妇高潮V片特黄| 国产精品观看在线亚洲人成网| 亚洲日韩中文字幕| 久久精品国产亚洲综合色| 国产亚洲精品免费| 无码视频免费一区二三区| 91热久久免费精品99| 91免费福利视频| 四虎国产精品永免费| 337P日本欧洲亚洲大胆艺术图|