android 对夏令时的处理 - Mr_Su

时间:2024-04-15 12:24:48

一般我们应用碰到要对时间的处理都是很麻烦的,比如实现万年历,会用到农历公历阳历阴历.. 

还有就是今天我想和大家一起讨论的夏令时,时差的问题.

之前做过一款世界天气+时钟的应用,包含全球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();

这样使用完全不精确的.

如果有人知道有更好的方法,麻烦指教一下