<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要多思考下 閱讀(6794) 評論(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  回復  更多評論
      

    主站蜘蛛池模板: 亚洲伦理中文字幕| 中文字幕无码日韩专区免费| 99在线观看免费视频| 亚洲色大成网站www永久一区| 美美女高清毛片视频黄的一免费 | 中文精品人人永久免费| 亚洲精品无码久久久| 国产男女爽爽爽免费视频| 久久亚洲欧洲国产综合| 国产日韩一区二区三免费高清| 国产亚洲色婷婷久久99精品 | 日本视频免费高清一本18| 亚洲va无码专区国产乱码| 97在线视频免费公开观看| 91亚洲国产成人久久精品网站| 2022久久国产精品免费热麻豆| 亚洲无删减国产精品一区| 37pao成人国产永久免费视频| 亚洲国产成人久久99精品| 成人人观看的免费毛片| 美女的胸又黄又www网站免费| 亚洲国产精品无码久久青草| 国产免费无码AV片在线观看不卡| 亚洲精选在线观看| 成年人网站在线免费观看| 日韩精品免费一线在线观看| 亚洲精品国产精品乱码在线观看| ww在线观视频免费观看| 亚洲AV无码AV日韩AV网站| 久久久久亚洲AV无码专区网站| 久久成人a毛片免费观看网站| 午夜在线a亚洲v天堂网2019| 亚洲欧洲国产成人综合在线观看| 精品国产污污免费网站| 亚洲av专区无码观看精品天堂| 全部免费毛片免费播放| 99精品在线免费观看| 久久精品国产亚洲AV| 亚洲一区二区三区高清| 国产免费牲交视频| 99久热只有精品视频免费看|