- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我遇到了 Jodatime 和 Android 的奇怪行为。我想解析字符串:
2014-05-19T18:13:00.000+02:00
转为DateTime,将年、月、时转为int。我开始在 IntelliJ Studio 上进行一些测试,然后做了类似的事情:
String date = "2014-05-19T18:13:00.000+02:00";
DateTime dateTime = new DateTime(date);
System.out.println(dateTime.toString());
System.out.println(dateTime.getYear());
System.out.println(dateTime.getMonthOfYear());
System.out.println(dateTime.getDayOfMonth());
System.out.println(dateTime.getHourOfDay());
System.out.println(dateTime.getMinuteOfHour());
System.out.println(dateTime.getMillis());
这给了我正确的答案:
2014-05-19T18:13:00.000+02:00
2014
5
19
18
13
1400515980000
现在,当我将 IDE 更改为 Android Studio 并执行相同操作时:
String dateT = "2014-05-19T18:13:00.000+02:00";
DateTime dateTime = new DateTime(dateT);
Lo.g(dateTime.getHourOfDay() + "");
Lo.g(dateTime.toString());
我的结果是:
16
2014-05-19T16:13:00.000Z
出于某种原因,Android Studio/Android 上的 DateTime 不考虑 +2:00 的时区。
我找不到解决方案。 Joda 中也没有简单的方法“addTimeZone”。
如何用DataTime显示正确的时间?我尝试了 LocalDateTime,使用 DateTimeZone.getDefault() 构造 DateTime(这给了我 UTF...)
最佳答案
既然你说你在两个平台上使用相同的 Joda-Time 版本,并且考虑到 Joda-Time 有自己的时区存储库,独立于系统时区数据,那么你观察到不同行为的原因可能只有一个解释: 显式或隐式的不同输入。让我们进入细节:
好吧,你说,给定相同的输入字符串,显然有相同的输入:
“2014-05-19T18:13:00.000+02:00”
所以我们有相同的(明确的)输入。但是等等,还有一件事:隐式默认设置,它也可以被视为一种抽象方式的输入。您使用构造函数 DateTime(Object)
。正如您在 source code 中所见,此构造函数首先委托(delegate)给 BaseDateTime
类的 super 构造函数.
public DateTime(Object instant) {
super(instant, (Chronology) null);
}
javadoc这个 super 构造函数的作者说:
"Constructs an instance from an Object that represents a datetime, using the specified chronology. If the chronology is null, ISO in the default time zone is used.
The recognised object types are defined in ConverterManager and include ReadableInstant, String, Calendar and Date."
所以最后我们看到 Joda-Time 使用默认时区。这确实是我通过研究源代码和文档可以看到的不同行为的唯一可能性。所有其他条件都相同:相同的库版本和相同的显式字符串输入以及相同的测试场景。
结论:您的平台上有不同的默认时区。请注意,您在两个平台上得到的是相同的瞬间,只是由于以下原因,用不同的本地时间戳和偏移量表示DateTime
对象内不同的内部时区/偏移设置。
更新:我已经用这段代码测试了区域覆盖行为:
String date = "2014-05-19T19:13:00.000+03:00"; // same instant as yours (just with offset +03)
DateTime dateTime = new DateTime(date);
System.out.println(dateTime.toString());
// output: 2014-05-19T18:13:00.000+02:00 (in my default timezone Europe/Berlin)
因此默认时区优先于字符串输入中的任何偏移量。如果您想使用解析后的偏移量,请查看使用 DateTimeFormatter及其方法 withOffsetParsed()
。
关于android - 如何使用时区从 JodaTime 获取小时数,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/23745821/
在我的 Rails (3.0) 应用程序中,我使用助手 time_zone_select() 来使用时区。它生成时区名称,如“(GMT+01:00) Paris”... 但这些名称与 MySQL 中的
我正在解析格式为的日期: SimpleDateFormat formatter = new SimpleDateFormat("EE MMM dd HH:mm:ss Z yyyy"); 当我这样做的时
我在 Android 上使用 ACTION_TIMEZONE_CHANGED Intent 过滤器来响应时区更改。 我注意到 Jodas 当前时区此时没有更新,使用:DateTimeZone.getD
我有一个旧版 Windows 应用程序,它从数据库读取数据。其中一列是“TimeZoneInfoId”。在传统世界中,它是由另一个 Windows 应用程序编写的,因此它存储 Windows 字符串:
我是数据库开发新手,目前从事 MySQL 工作。我有一列包含美国的所有时区。我希望能够获取每行中每个时区的当前时间(只有时间,没有日期)。 时区数据如下:+05:00、-03:00 等等 这就是我尝试
我正在尝试了解 session 时区在 PostgreSQL 中的工作原理。 当我将 session 时区设置为“01:00”时,返回日期为“-01:00”。符号总是颠倒的,我不理解这种行为。 这怎么
我写入我的 mongoDB 数据库,例如开始日期,开始日期始终是一周中的星期一(我使用并且我在欧洲中部时区)。 "startDate" : ISODate("2014-12-28T23:00:00Z"
是否有详尽的 MySQL 时区列表? 似乎 MySQL 设置中 time_zone 的有效值取决于主机操作系统,但我一直无法找到可能值的列表。 我需要时间显示卡尔加里本地时间。 最佳答案 默认情况下,
我已经在 config/app.php 中配置了时区至 Europe/Lisbon . 如果我做 return date_default_timezone_get(); , 返回 Europe/Lis
我在整个脚本中广泛使用 unix 时间,通常我将时区设置如下: date_default_timezone_set('Europe/London'); 这一直工作正常,直到上周末时钟回退一个小时,我怀
我有一个字符串,2013-10-07T23:59:51.205-07:00,想将其转换为 Java 日期对象。我收到解析错误。 date = new SimpleDateFormat("yyyy-MM
如何更改日志文件名中的 log4j 时区? 我的 log4j.xml 文件:
在JAVA中,如何确定所有日期都作为GMT日期返回? 例如,即使我尝试使用GMT语言环境强制使用DateFormat,它也会应用某种逻辑来检索BST日期。 public static void mai
好吧,这是我遇到过的最奇怪的错误之一! 首先:我不是 Python 程序员,该脚本是由 friend 编写的(我认为他的大部分内容来自示例)。 该脚本的用途:将日历信息(CET 时间)从 XML 文件
我们有一个网站,目前在某个时间(由用户选择)运行拍卖,这一切都工作正常,因为当服务器到达该时间时,拍卖就会开始。然后我们必须添加时区,具体取决于用户居住的地方。然后,根据所选的下拉菜单,这将增加或减少
我陷入了这个逻辑。我正在开发一个消息调度项目,我的客户来自不同的国家。让我们考虑一下亚洲(不遵守夏令时)和美国/纽约(遵守夏令时)。 现在,我正在编写以下查询来获取距当前时间 10 分钟间隔内的时间表
我尝试返回特定时区的值,但我遇到了一些奇怪的响应行为: SELECT created_at AT TIME ZONE 'US/Pacific' - created_at, NOW() A
我正在尝试将不带时区值(例如“31.05.2015”)的字符串转换为 NSDate。 我的 DateFormatter 有什么问题?它返回日期 2015-05-31 22:00:00 +0000当我尝
我已经成功地将我的本地 tzinfo 导入到 mysql 中,我几乎已经了解了关于如何存储和使用这些数据的所有细节,除了一个字段。有一个名为 Transition_type_id 的数字字段(在表 t
为什么以下行返回的 TimeZone 显示不正确的时间: TimeZone.getTimeZone("America/Ottawa") 现在显示晚上 10:26 [亚特兰大时间现在是 6:26,Ott
我是一名优秀的程序员,十分优秀!