一般我們應用碰到要對時間的處理都是很麻煩的,比如實現萬年曆,會用到農曆西曆陽曆陰曆..
還有就是今天我想和大家一起討論的夏令時,時差的問題.
之前做過一款世界天氣+時鐘的應用,包含全球3萬多個城市的天氣和時間.
天氣,時差這些問題都好說,就是夏令時這一塊把我弄煩了.不過想想也正常,霸氣外露的IPHONE前不久不也陷入過夏令時的困擾嗎
一般要做這類和時間打交道的應用,我們一定有一塊資料是關於時差的.
比如 China offset:+8
我們根據這個offset 再和格林威治時間計算就能得到China的目前時間.
而進入夏令時時,有的地區(注意是地區不是國家,美國有些國家採用夏令時,有的卻不- -#).這個offset會根據是否是夏令時而增減1小時左右(我記得貌似有些進入夏令時的地區還有半個小時偏差的)
而現在最大的困難是---你無法得知某個城市是否進入夏令時!!! 剛開始我天真的以為,能得到類似GMT+8:00的offset就能得知這個地區是否施行夏令時,但是這就大錯特錯了.因為我上面提到過,同一個國家,甚至同一塊地區都不確定是否統一的施行夏令時.也就是說都屬於GMT+5:00這樣一個timezone的地區,有的可能使用有的可能沒使用夏令時.
我理解的是時區是按經度劃分的,每15度是一個時區,所以剛好一共是24個時區. 在GMT+5:00的地方,然後不同緯度的施行夏令時不同
所以我們從資料中得到的offset(+8:00) 不能直接得到夏令時的使用方式,而且這個offset不一定是正確的,它應該隨夏令時而改變.
我們現在來看看android 的 API:
TimeZone.getTimeZone (String specifiedID) 首先和我們要處理的問題相關有這麼樣一個方法, 但是參數是一個String類型的specifiedID
這個specifiedID怎麼得到呢?我們會用到 String[] specifiedIDs= TimeZone.getAvailableIDs(offsetGMT * 60 * 60 * 1000);
就得到specifiedIDs一個數組, 然后里面有很多specifiedID 比如: Asia/Brunei , Asia/Choibalsan , Asia/Chongqing ....
根據這個specifiedID 我們就可以得到這個TimeZone對象了
String[] specifiedIDs= TimeZone.getAvailableIDs(offsetGMT * 60 * 60 * 1000);
String timeZoneID = TimeZone.getTimeZone(specifiedIDs[0]).getID();
Time time = new Time(timeZoneID);
然後android有自動幫你實現夏令時,我們得到的time就可以直接使用,會隨著進入夏令時時間發生變化.
最後遺留一個問題,就是關於specifiedID的問題 ,我這裡是預設取的第一個
TimeZone.getTimeZone(specifiedIDs[0]).getID();
這樣使用完全不精確的.
如果有人知道有更好的方法,麻煩指教一下