参考资料
- Using new Java 8 DateTimeFormatter to do strict date parsing
- Javaにおける日付文字列の書式チェック方法
- Java8のDate and Time APIではyyyyじゃなくてuuuuを使う
零. 总结
⏹在Java8的新日期API下,yyyy
代表公元纪年(year-of-era),而uuuu
代表和公元没有关系的年
⏹使用java8的日期API进行开发的时候,大多数使用的都是uuuu
。
⏹字符串转换为LocalDate等时间的时候,建议开启严格模式。
一. 非严格模式下
以2023/02/29
为例子,2023年的2月份不可能有29天。
- 若允许此日期合法,则为非严格。
- 若不允许此日期合法,则为严格。
⏹当DateTimeFormatter.ofPattern()
进行非严格模式下的格式化的时候,
yyyy/MM/dd
和uuuu/MM/dd
表现相同,都是转换为合法的日期。
String str1 = "2023/02/29";
DateTimeFormatter formatter1 = DateTimeFormatter.ofPattern("yyyy/MM/dd");
LocalDate localDate1 = LocalDate.parse(str1, formatter1);
System.out.println(localDate1); // 2023-02-28
DateTimeFormatter formatter1_1 = DateTimeFormatter.ofPattern("uuuu/MM/dd");
LocalDate localDate1_1 = LocalDate.parse(str1, formatter1_1);
System.out.println(localDate1_1); // 2023-02-28
二. 严格模式下
DateTimeFormatter.ofPattern()
通过.withResolverStyle(ResolverStyle.STRICT)
来开启严格模式。
2.1 yyyy
⏹虽然2023/02/28
是一个合法的日期,但是yyyy
代表公元纪年,且开启了严格模式,2023/02/28
并不包含公元,因此程序报错。
String str2 = "2023/02/28";
DateTimeFormatter formatter2 = DateTimeFormatter.ofPattern("yyyy/MM/dd")
.withResolverStyle(ResolverStyle.STRICT);
try {
LocalDate localDate2 = LocalDate.parse(str2, formatter2);
System.out.println(localDate2);
} catch (Exception ex) {
System.out.println(ex.getMessage());
// Text '2023/02/28' could not be parsed:
// Unable to obtain LocalDate from TemporalAccessor:
// {DayOfMonth=28, YearOfEra=2023, MonthOfYear=2},ISO of type java.time.format.Parsed
}
⏹这次使用G yyyy/MM/dd
来进行格式化,并且日期也添加了西暦
,因此在严格模式下也能格式化成功。
String str3 = "西暦 2023/02/28";
/* * Locale.JAPAN --> "西暦 2023/02/28" * Locale.CHINA --> "公元 2023/02/28" * Locale.US --> "AD 2023/02/28" */
DateTimeFormatter formatter3 = DateTimeFormatter.ofPattern("G yyyy/MM/dd", Locale.JAPAN)
.withResolverStyle(ResolverStyle.STRICT);
LocalDate localDate3 = LocalDate.parse(str3, formatter3);
System.out.println(localDate3); // 2023-02-28
2.2 uuuu
⏹因为开启了严格模式下的日期格式化,因此2023/02/29
这种不存在的日期会异常。
// 严格模式下的日期格式化
DateTimeFormatter formatter4 = DateTimeFormatter.ofPattern("uuuu/MM/dd")
.withResolverStyle(ResolverStyle.STRICT);
try {
LocalDate.parse("2023/02/29", formatter4);
} catch (Exception ex) {
System.out.println(ex.getMessage());
// Text '2023/02/29' could not be parsed: Invalid date 'February 29' as '2023' is not a leap year
}
LocalDate localDate4 = LocalDate.parse("2023/02/28", formatter4);
System.out.println(localDate4); // 2023-02-28
三. JapaneseDate
⏹若想让日期格式化之后含日本年号,则应使用G yy/MM/dd
。
import java.time.chrono.JapaneseDate;
JapaneseDate japaneseDate1 = JapaneseDate.of(2017, 10, 22);
String japaneseDate_str_1 = japaneseDate1.format(DateTimeFormatter.ofPattern("G uuuu/MM/dd", Locale.JAPAN));
System.out.println(japaneseDate_str_1); // 平成 2017/10/22
JapaneseDate japaneseDate2 = JapaneseDate.from(LocalDate.now());
String japaneseDate_str_2 = japaneseDate2.format(DateTimeFormatter.ofPattern("G yyyy/MM/dd", Locale.JAPAN));
System.out.println(japaneseDate_str_2); // 平成 0035/09/27
今天的文章Java8 yyyy/MM/dd和uuuu/MM/dd的不同分享到此就结束了,感谢您的阅读。
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。
如需转载请保留出处:http://bianchenghao.cn/89253.html