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

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

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

    java要多思考下

    成長^_^

       ::  :: 新隨筆 ::  ::  :: 管理 ::
      33 隨筆 :: 0 文章 :: 19 評論 :: 0 Trackbacks
    最近項目中實現了一個課程表的功能,核心功能如下:
    1、需要記錄一周里每天每個時段的課程安排,后臺錄入
    2、課程開始前,需要自動給課程關注者以各種提醒

    于是采用了這樣的實現方案:
    1、錄入時間只記錄當天的時分秒對應的毫秒數(這樣入庫的時間實際上是1970-01-01 HH:mm:ss)
    2、定時任務根據當天所在的周數查詢當天的課程安排,并將課程時間換算成當天的時間(2015-09-08 HH:mm:ss),然后執行提醒的業務

    很簡單的一個功能,但是因為時區問題出現了以下奇葩現象:

    比如1970-01-01 10:00:00被最終換算成了1970-01-01 10:30:00
    也就是說每一個入庫時間取出后都增加了不多不少半個小時

    于是開始看java.util.Date源碼,一探究竟,發現有這樣一段:
            BaseCalendar cal = getCalendarSystem(year);
                if (tzoffset == -1)  { // no time zone specified, have to use local
            BaseCalendar.Date ldate = (BaseCalendar.Date) cal.newCalendarDate(TimeZone.getDefaultRef());

    注意到TimeZone.getDefaultRef(),源碼如下:
        public static TimeZone getDefault() {
            return (TimeZone) getDefaultRef().clone();
        }

        /**
         * Returns the reference to the default TimeZone object. This
         * method doesn't create a clone.
         
    */
        static TimeZone getDefaultRef() {
        TimeZone defaultZone = defaultZoneTL.get();
        if (defaultZone == null) {
            defaultZone = defaultTimeZone;
            if (defaultZone == null) {
            // Need to initialize the default time zone.
            defaultZone = setDefaultZone();
            assert defaultZone != null;
            }
        }
        // Don't clone here.
        return defaultZone;
        }

    推測很有可能問題出在時區的選擇設置上,于是打印出來結果如下:
    sun.util.calendar.ZoneInfo[id="Asia/Harbin",offset=28800000,dstSavings=0,useDaylight=false,transitions=19,lastRule=null]
    果然如此,服務器時區錯誤,于是指出這個錯誤,讓運維修正的。
    不過還是擔心運維層面帶來類似的錯誤,于是手動設置了時區:

        TimeZone.setDefault(TimeZone.getTimeZone("Asia/Shanghai"));
            logger.info("the default timezone info [{}]", TimeZone.getDefault());

    技術文章收藏站點












    posted on 2015-09-08 23:03 java要多思考下 閱讀(6786) 評論(1)  編輯  收藏 所屬分類: 技術研究

    評論

    # re: 【原】JAVA時區設置及時區不一致帶來的奇葩現象 2015-09-14 08:42 Kizi 2
    Recent projects implemented in the function of a curriculum, the core functions are as follows  回復  更多評論
      

    主站蜘蛛池模板: 皇色在线免费视频| 成人福利在线观看免费视频| 久久午夜羞羞影院免费观看| 国产成人亚洲精品91专区手机| 猫咪www免费人成网站| 免费一级大黄特色大片| 一级特级aaaa毛片免费观看| 国产日产亚洲系列最新| 中文字幕的电影免费网站| 亚洲av无码av制服另类专区| 日韩人妻一区二区三区免费| 亚洲天堂中文字幕在线观看| 24小时免费直播在线观看| 美女无遮挡免费视频网站| 久久久久亚洲爆乳少妇无| 免费a级毛片无码a∨免费软件 | 全部免费a级毛片| xxxxx做受大片视频免费| 国产亚洲一区二区精品| 亚洲黄色免费电影| 亚洲高清乱码午夜电影网| 免费一级做a爰片性色毛片| 成人精品一区二区三区不卡免费看 | 国产精品久久久久久亚洲影视| 亚洲国产av无码精品| 中文日本免费高清| 亚洲另类小说图片| 亚洲AV无码乱码在线观看| 99精品免费视品| 在线a亚洲老鸭窝天堂av高清| mm1313亚洲精品国产| 一个人免费视频观看在线www | 一个人看的www免费视频在线观看| 亚洲三级电影网址| 国产成人免费片在线观看 | 中文字幕看片在线a免费| 亚洲一区免费视频| 国产成人亚洲综合| 一个人看的www在线观看免费| 特级毛片爽www免费版| 亚洲国产精品成人综合久久久 |