【Android 国际化】碰到有关日期的时区问题,咱们该怎么办?终极大招来了。。

###背景 为何想到要写一篇关于时区问题的blog?由于。。 去年Colin参与开发了公司的一个独立app的开发,其中我只负责了“多目的地选择页”的开发,说白了就是去打了个酱油。。可这酱油仍是没彻底白打,我发现项目经理、产品、开发、测试们在项目后期都在纠结时区问题。虽然我也跟着开了几场关于时区问题的会,可因为我没有真正参与吧,并无真正理解为啥时区会出问题。。 不过Colin从那时就告诉本身,下次等我遇到时区问题时,必定要好好研究,这块内容貌似挺有意思的。。 就这样,真让我等来了。。 ###为何会有时区问题? 1. 国际化app中须要展现时间时 2. app中用到了Calendar类orDate类时

总的来讲,当须要把Date转化成时间字符串时,还有就是用到了Calendar类来计算时间时,若是用户在国外使用你的app时就可能存在时区问题。这里说的时区问题究竟是什么问题呢?
好比,北京时间5月23号5:30时,另一个半球的国家颇有多是5月22号晚上,那么一个字符串“2018-5-23 5:30”通过转为Date就转成了当地的Date,当这个Date再转成字符串时就再也不是“2018-5-23 5:30”了。
###该如何解决时区问题?
####1. 关于时区的几个基本概念
要想完全理解时区问题,咱们须要先了解几个基本概念。html

1.协调世界时:Coordinated Universal Time(UTC):
是英国格林尼治时间,格林尼治时间被称为零时区时间,也被称为绝对时间。
2.格林尼治标准时:Greenwich Mean Time(GMT):
是指位于伦敦郊区的皇家格林尼治天文台的标准时间,因为地球在它的椭圆轨道里的运动速度不均匀,这个时刻可能和实际的太阳时相差16分钟。 如今都采用UTC时间,是校订过的GMT时间。
####2. Android中处理时区问题的办法
把当地时间都转为北京时间处理,这里有两个办法
#####(1)全局设置app时区为北京时区web

TimeZone chinaTimeZone = TimeZone.getTimeZone("GMT+8");
TimeZone.setDefault(chinaTimeZone);

这个方法比较暴力,咱们以前的独立app就是采用这种办法。不过,考虑到可能影响其余页面的功能,我没有采用这种办法。
####(2)在须要处理时间时,把本地时区的Date转为北京地区的Dateapp

//转换任意时区的办法(本篇blog精髓)
private fun changeTimeZone(date: Date, oldZone: TimeZone, newZone: TimeZone): Date {
        var dateTmp: Date
        val timeOffset = oldZone.rawOffset - newZone.rawOffset
        dateTmp = Date(date.time - timeOffset)
        return dateTmp
}
//将当地时间转为北京时间的方法
fun getDateOfBJTimeZone(date: Date): Date {
        var originTimeZone = TimeZone.getDefault()
        var bjTimeZone = TimeZone.getTimeZone("Asia/Shanghai")
        return changeTimeZone(date, originTimeZone, bjTimeZone)
}

上面提供了两个Date转换的方法,那须要用到Calendar类时,能够给Calendar设置一个时区的,办法以下:svg

val c = Calendar.getInstance()
c.timeZone = TimeZone.getTimeZone("Asia/Shanghai")
c.timeInMillis = date.time
c.add(Calendar.DATE, days)

一样,String和Date互转时也能够设置时区,办法以下:测试

val dateFormat = SimpleDateFormat(type)
val timeZone = TimeZone.getTimeZone("Asia/Shanghai")
dateFormat.timeZone = timeZone
str = dateFormat.format(date)

###参考.net

http://www.cnblogs.com/endure/p/3485281.html
https://www.jianshu.com/p/098c16b39f9b
https://blog.csdn.net/l_serein/article/details/6273362
http://www.cnblogs.com/endure/p/3485281.html
https://www.cnblogs.com/wenfei123chai/p/4267998.html
https://blog.csdn.net/lovext4098477/article/details/46866879code