我们的想法是构建一个事件(自定义类事件),用户可以在几小时和几分钟内写下他希望事件发生的时间,并从calendarView中选择日期。 所以我得到他从视图中选择的日期以及他希望事件开始的时间并将它们放入事件对象中。问题是,当我创建它时,它会将日期设置为GMT-3(我的默认值),但我希望日期在EST中。由于应用程序将主要由使用EST格式的人使用,如果我创建事件,它将显示错误的他们和反之,如果我想为这些事件设置通知他们将是不正确的。 有没有办法在EST中创建日期?
通过这种方式,如果他们在美国东部时间创建了一个日期并且我从手机中读取了它,它会在我的时区显示它不会吗?
答案 0 :(得分:0)
捕获输入。
Instant instant =
OffsetDateTime.of( LocalDate.of( 2016 , 1 , 2 ) ,
LocalTime.of( 12 , 34 , 56 ) ,
ZoneOffset.ofHours( -3 )
)
.toInstant() ;
使用任何Locale
生成任何时区的演示文稿。
String output =
instant.atZone( ZoneId.of( "Pacific/Auckland" ) )
.format( DateTimeFormatter.ofLocalizedDateTime( FormatStyle.FULL )
.withLocale( Locale.CANADA_FRENCH )
) ;
指定proper time zone name。切勿使用诸如EST
或IST
之类的3-4字母缩写,因为它们不是真正的时区,不是标准化的,甚至不是唯一的(!)。
offset-from-UTC是与人们在设置时钟时间时使用的特定地点wall-clock time的UTC不同的小时数,分钟数和秒数。
时区是偏移加上一组处理异常的规则。
因此GMT-3
不您的时区,这是您的偏移量。您的时区可能是America/Buenos_Aires
,Antarctica/Rothera
等。
由于时区提供了更多信息和更多功能,因此请始终优先使用时区而不仅仅是偏移量。
提示:始终使用冒号分隔填充零和小时和分钟的偏移量。 ISO 8601标准允许其他变体,但有时在各种协议或软件系统中不支持。因此,请使用-03:00
而不是-3
。
不要使用与最早版本的Java捆绑在一起的臭名昭着的旧版旧类。避免使用java.util.Date
,java.util.Calendar
,SimpleDateFormat
等。现在取代了java.time类。
LocalDate
& LocalTime
java.time中的LocalDate
和LocalTime
类型表示仅限日期或仅限时间的值,且没有时区。使用这些来从您的小部件收集数据。 “本地”意味着“未划定”,缺少偏移或时区含义。
LocalDate ld = LocalDate.of( 2016 , 1 , 2 );
LocalTime lt = LocalTime.of( 12 , 34 , 56 );
OffsetDateTime
如果我们所拥有的是三小时的偏移而不是一个完整的时区,则解释这一对LocalDate
& LocalTime
作为具有ZoneOffset
对象的OffsetDateTime
对象。
ZoneOffset offset = ZoneOffset.ofHours( -3 );
OffsetDateTime odt = OffsetDateTime.of( ld , lt , offset );
ZonedDateTime
如果我们确实考虑了时区,请应用ZoneId
获取ZonedDateTime
。
ZoneId z = ZoneId.of( "America/Buenos_Aires" );
ZonedDateTime zdt = ZonedDateTime.of( ld , lt , z );
Instant
以UTC格式进行大部分业务逻辑,数据存储和数据交换。仅在需要时应用偏移或时区,例如向用户显示。
Instant
类代表UTC中时间轴上的一个时刻,分辨率为nanoseconds。
您可以从其他类型中提取Instant
个对象。
Instant instant = zdt.toInstant();
将瞬间调整到您可能想要的任何其他时区。
ZonedDateTime zdtNewYork = instant.atZone( ZoneId.of( "America/New_York" ) );
ZonedDateTime zdtParis = instant.atZone( ZoneId.of( "Europe/Paris" ) );
ZonedDateTime zdtAuckland = instant.atZone( ZoneId.of( "Pacific/Auckland" ) );
这些对象都代表同一时刻,即时间轴上的同一点。它们的不同之处仅在于我们通过每个地区wall-clock time的镜头观察同一时刻。
请记住,字符串不是日期时间值;它们是日期时间值文本中的表示。
因此,日期时间对象可以生成您想要的任何格式的字符串。您可以指定自定义格式。但通常最好让java.time自动为localize。
要进行本地化,请指定:
FormatStyle
确定字符串的长度或缩写。Locale
确定(a)翻译日期名称,月份名称等的人类语言,以及(b)决定缩写,大小写,标点符号等问题的文化规范。< / LI>
示例:
Locale l = Locale.CANADA_FRENCH ;
DateTimeFormatter f = DateTimeFormatter.ofLocalizedDateTime( FormatStyle.FULL ).withLocale( l );
String output = zdt.format( f );
请注意,Locale
与时区正交,完全无关。您可以使用Pacific/Auckland
分区值的法语演示文稿,或Europe/Copenhagen
分区值的印度语演示文稿。
java.time框架内置于Java 8及更高版本中。这些类取代了麻烦的旧日期时间类,例如java.util.Date
,.Calendar
和&amp; java.text.SimpleDateFormat
。
现在位于Joda-Time的maintenance mode项目建议迁移到java.time。
要了解详情,请参阅Oracle Tutorial。并搜索Stack Overflow以获取许多示例和解释。
大部分java.time功能都被反向移植到Java 6&amp; ThreeTen-Backport中的7,并进一步适应Android中的ThreeTenABP(见How to use…)。
ThreeTen-Extra项目使用其他类扩展java.time。该项目是未来可能添加到java.time的试验场。您可以在此处找到一些有用的课程,例如Interval
,YearWeek
,YearQuarter
等。