- 所有已实现的接口:
Serializable,Comparable<Chronology>,Chronology
该年表定义了日本皇历系统的规则。这种日历系统主要用于日本。除了基于纪元的年份编号之外,日本帝国日历系统与 ISO 日历系统相同。
日本从明治六年开始引入公历,只支持明治以后的纪元;不支持明治 6 月 1 日之前的日期。
支持的 ChronoField 实例是:
DAY_OF_WEEKDAY_OF_MONTHDAY_OF_YEAREPOCH_DAYMONTH_OF_YEARPROLEPTIC_MONTHYEAR_OF_ERAYEARERA
- 实现要求:
- 这个类是不可变的和线程安全的。
- 自从:
- 1.8
- 参见:
-
字段摘要
字段 -
方法总结
修饰符和类型方法描述date(int prolepticYear, int month, int dayOfMonth) 从 proleptic-year、month-of-year 和 day-of-month 字段中获取日本日历系统中的本地日期。从时代、时代年、年月和月日字段中获取日本日历系统中的本地日期。date(TemporalAccessor temporal) 从另一个时间对象获取此年表中的本地日期。dateEpochDay(long epochDay) 从纪元日获取日本日历系统中的本地日期。dateNow()从默认时区的系统时钟获取此年表中的当前本地日期。从指定的时钟获取此年表中的当前本地日期。从指定时区的系统时钟获取此年表中的当前本地日期。dateYearDay(int prolepticYear, int dayOfYear) 从 proleptic-year 和 day-of-year 字段中获取日本日历系统中的本地日期。dateYearDay(Era era, int yearOfEra, int dayOfYear) 从时代、时代年份和年份字段中获取日本日历系统中的本地日期。eraOf(int eraValue) 从给定的数值返回日历系统纪元对象。eras()获取年表的纪元列表。获取基础日历系统的日历类型 - 'japanese'。getId()获取年表的 ID - 'Japanese'。booleanbooleanisLeapYear(long prolepticYear) 检查指定年份是否为闰年。localDateTime(TemporalAccessor temporal) 从另一个时间对象获取此年表中的本地日期时间。intprolepticYear(Era era, int yearOfEra) 计算给定时代和时代的预期年份。range(ChronoField field) 获取指定字段的有效值范围。resolveDate(Map<TemporalField, Long> fieldValues, ResolverStyle resolverStyle) 在解析期间将已解析的ChronoField值解析为日期。zonedDateTime(Instant instant, ZoneId zone) 从Instant获得此年表中的ChronoZonedDateTime。zonedDateTime(TemporalAccessor temporal) 从另一个时间对象获得此年表中的ChronoZonedDateTime。在类 java.time.chrono.AbstractChronology 中声明的方法
compareTo, equals, hashCode, toString在接口 java.time.chrono.Chronology 中声明的方法
epochSecond, epochSecond, getDisplayName, period
-
字段详细信息
-
INSTANCE
日本年表的单例实例。
-
-
方法详情
-
getId
获取年表的 ID - 'Japanese'。ID 唯一标识
Chronology。它可用于使用Chronology.of(String)查找Chronology。- 指定者:
getId在接口Chronology中- 返回:
- 年表 ID - 'Japanese'
- 参见:
-
getCalendarType
获取基础日历系统的日历类型 - 'japanese'。日历类型是由 Unicode Locale Data Markup Language (LDML) 规范定义的标识符。它可用于使用
Chronology.of(String)查找Chronology。它也可以用作区域设置的一部分,可通过Locale.getUnicodeLocaleType(String)使用键“ca”访问。- 指定者:
getCalendarType在接口Chronology中- 返回:
- 日历系统类型 - 'japanese'
- 参见:
-
date
从时代、时代年、年月和月日字段中获取日本日历系统中的本地日期。日本的月份和日期与 ISO 日历系统中的相同。当时代改变时,它们不会被重置。例如:
6th Jan Showa 64 = ISO 1989-01-06 7th Jan Showa 64 = ISO 1989-01-07 8th Jan Heisei 1 = ISO 1989-01-08 9th Jan Heisei 1 = ISO 1989-01-09
- 指定者:
date在接口Chronology中- 参数:
era- 日本时代,不为空yearOfEra- 年代month- 月份dayOfMonth- 每月的第几天- 返回:
- 日本本地日期,不为空
- 抛出:
DateTimeException- 如果无法创建日期ClassCastException- 如果era不是JapaneseEra
-
date
从 proleptic-year、month-of-year 和 day-of-month 字段中获取日本日历系统中的本地日期。日本的年、月、日与 ISO 日历系统中的相同。当时代改变时,它们不会被重置。
- 指定者:
date在接口Chronology中- 参数:
prolepticYear- 预兆年month- 月份dayOfMonth- 每月的第几天- 返回:
- 日本本地日期,不为空
- 抛出:
DateTimeException- 如果无法创建日期
-
dateYearDay
从时代、时代年份和年份字段中获取日本日历系统中的本地日期。该工厂中的年份是相对于年份开始的日期来表示的。此定义仅在由于时代变化而将时代重置为一年的那些年份中改变了一年中的一天的正常含义。例如:
6th Jan Showa 64 = day-of-year 6 7th Jan Showa 64 = day-of-year 7 8th Jan Heisei 1 = day-of-year 1 9th Jan Heisei 1 = day-of-year 2
- 指定者:
dateYearDay在接口Chronology中- 参数:
era- 日本时代,不为空yearOfEra- 年代dayOfYear- 一年中的第几天- 返回:
- 日本本地日期,不为空
- 抛出:
DateTimeException- 如果无法创建日期ClassCastException- 如果era不是JapaneseEra
-
dateYearDay
从 proleptic-year 和 day-of-year 字段中获取日本日历系统中的本地日期。这家工厂的年份是相对于预产年的开始表示的。日本的预历年和日期与 ISO 日历系统中的相同。当时代改变时,它们不会被重置。
- 指定者:
dateYearDay在接口Chronology中- 参数:
prolepticYear- 预兆年dayOfYear- 一年中的第几天- 返回:
- 日本本地日期,不为空
- 抛出:
DateTimeException- 如果无法创建日期
-
dateEpochDay
从纪元日获取日本日历系统中的本地日期。- 指定者:
dateEpochDay在接口Chronology中- 参数:
epochDay- 纪元日- 返回:
- 日本本地日期,不为空
- 抛出:
DateTimeException- 如果无法创建日期
-
dateNow
从接口Chronology复制的描述从默认时区的系统时钟获取此年表中的当前本地日期。这将在默认时区查询
system clock以获取当前日期。使用此方法将阻止使用备用时钟进行测试的能力,因为时钟是硬编码的。
- 指定者:
dateNow在接口Chronology中- 返回:
- 使用系统时钟和默认时区的当前本地日期,不为空
-
dateNow
从接口Chronology复制的描述从指定时区的系统时钟获取此年表中的当前本地日期。这将查询
system clock以获取当前日期。指定时区避免了对默认时区的依赖。使用此方法将阻止使用备用时钟进行测试的能力,因为时钟是硬编码的。
- 指定者:
dateNow在接口Chronology中- 参数:
zone- 要使用的区域 ID,不为空- 返回:
- 使用系统时钟的当前本地日期,不为空
-
dateNow
从接口Chronology复制的描述从指定的时钟获取此年表中的当前本地日期。这将查询指定的时钟以获取当前日期 - 今天。使用此方法允许使用备用时钟进行测试。可以使用
dependency injection引入备用时钟。- 指定者:
dateNow在接口Chronology中- 参数:
clock- 使用的时钟,不为空- 返回:
- 当前本地日期,不为空
-
date
从接口Chronology复制的描述从另一个时间对象获取此年表中的本地日期。这将根据指定的时间获取此年表中的日期。
TemporalAccessor表示一组任意的日期和时间信息,该工厂将其转换为ChronoLocalDate的一个实例。转换通常使用跨日历系统标准化的
EPOCH_DAY字段。此方法与功能接口
TemporalQuery的签名相匹配,允许它通过方法引用aChronology::date用作查询。- 指定者:
date在接口Chronology中- 参数:
temporal- 要转换的时间对象,不为空- 返回:
- 此年表中的本地日期,不为空
- 参见:
-
localDateTime
从接口Chronology复制的描述从另一个时间对象获取此年表中的本地日期时间。这将根据指定的时间在此年表中获取日期时间。
TemporalAccessor表示一组任意的日期和时间信息,该工厂将其转换为ChronoLocalDateTime的一个实例。转换从时间对象中提取并组合
ChronoLocalDate和LocalTime。允许实现执行优化,例如访问与相关对象等效的那些字段。结果使用此年表。此方法与功能接口
TemporalQuery的签名相匹配,允许它通过方法引用aChronology::localDateTime用作查询。- 指定者:
localDateTime在接口Chronology中- 参数:
temporal- 要转换的时间对象,不为空- 返回:
- 此年表中的本地日期时间,不为空
- 参见:
-
zonedDateTime
从接口Chronology复制的描述从另一个时间对象获得此年表中的ChronoZonedDateTime。这将根据指定的时间在此年表中获得分区日期时间。
TemporalAccessor表示一组任意的日期和时间信息,该工厂将其转换为ChronoZonedDateTime的一个实例。转换将首先从时间对象获取
ZoneId,必要时回落到ZoneOffset。然后它将尝试获取Instant,必要时回落到ChronoLocalDateTime。结果将是ZoneId或ZoneOffset与Instant或ChronoLocalDateTime的组合。允许实现执行优化,例如访问与相关对象等效的那些字段。结果使用此年表。此方法与功能接口
TemporalQuery的签名相匹配,允许它通过方法引用aChronology::zonedDateTime用作查询。- 指定者:
zonedDateTime在接口Chronology中- 参数:
temporal- 要转换的时间对象,不为空- 返回:
- 此年表中的分区日期时间,不为空
- 参见:
-
zonedDateTime
从接口Chronology复制的描述从Instant获得此年表中的ChronoZonedDateTime。这将获得与指定时刻具有相同时刻的分区日期时间。
- 指定者:
zonedDateTime在接口Chronology中- 参数:
instant- 创建日期时间的时刻,不为空zone- 时区,不为空- 返回:
- 分区日期时间,不为空
-
isLeapYear
public boolean isLeapYear(long prolepticYear) 检查指定年份是否为闰年。日本日历闰年与 ISO 闰年完全一致。此方法不验证传入的年份,并且只有支持范围内年份的明确定义的结果。
- 指定者:
isLeapYear在接口Chronology中- 参数:
prolepticYear- 要检查的预期年份,未针对范围进行验证- 返回:
- 如果这一年是闰年,则为真
-
prolepticYear
从接口Chronology复制的描述计算给定时代和时代的预期年份。这将时代和时代结合到单一的预测年字段。
如果年表积极使用纪元,例如
JapaneseChronology,那么纪元年将根据纪元进行验证。对于其他年表,验证是可选的。- 指定者:
prolepticYear在接口Chronology中- 参数:
era- 年表正确类型的时代,不为空yearOfEra- 纪年年代- 返回:
- 推算年份
-
eraOf
从给定的数值返回日历系统纪元对象。该方法支持的数值与JapaneseEra.of(int)支持的数值相同。- 指定者:
eraOf在接口Chronology中- 参数:
eraValue- 时代值- 返回:
-
给定数字纪元值的日语
Era - 抛出:
DateTimeException- 如果eraValue无效
-
eras
从接口Chronology复制的描述获取年表的纪元列表。大多数日历系统都有一个时代,其中年份具有意义。如果日历系统不支持时代的概念,则必须返回一个空列表。
- 指定者:
eras在接口Chronology中- 返回:
- 年表的时代列表,可能是不可变的,不为空
-
range
从接口Chronology复制的描述获取指定字段的有效值范围。所有字段都可以表示为一个
long整数。此方法返回一个描述该值有效范围的对象。请注意,结果仅描述了最小和最大有效值,重要的是不要过多地解读它们。例如,范围内可能存在对该字段无效的值。
无论年表是否支持该字段,此方法都会返回一个结果。
- 指定者:
range在接口Chronology中- 参数:
field- 获取范围的字段,不为空- 返回:
- 该字段的有效值范围,不为空
-
resolveDate
public JapaneseDate resolveDate(Map <TemporalField , Long > fieldValues, ResolverStyle resolverStyle) 从类复制的描述:AbstractChronology在解析期间将已解析的ChronoField值解析为日期。大多数
TemporalField实现都是使用字段上的 resolve 方法解析的。相比之下,ChronoField类定义的字段仅与年表相关。因此,ChronoField日期字段在特定年表的上下文中在此处解析。ChronoField实例通过此方法解析,可能在子类中被覆盖。EPOCH_DAY- 如果存在,则将其转换为日期,然后根据日期交叉检查所有其他日期字段。PROLEPTIC_MONTH- 如果存在,则将其拆分为YEAR和MONTH_OF_YEAR。如果模式是严格的或智能的,则验证该字段。YEAR_OF_ERA和ERA- 如果两者都存在,则它们组合起来形成一个YEAR。在宽松模式下,YEAR_OF_ERA范围未被验证,在智能和严格模式下它是。ERA在所有三种模式下都针对范围进行了验证。如果只有YEAR_OF_ERA存在,并且模式是 smart 或 lenient,则假定最后一个可用时代。在严格模式下,不假定任何纪元,YEAR_OF_ERA保持不变。如果只有ERA存在,则保持不变。YEAR、MONTH_OF_YEAR和DAY_OF_MONTH- 如果所有三个都存在,则将它们组合起来形成一个日期。在所有三种模式中,YEAR都经过验证。如果模式是 smart 或 strict,则验证月份和日期。如果模式宽松,那么日期的组合方式相当于在所请求年份的第一个月的第一天创建一个日期,然后加上月差,然后加上天差。如果模式是智能的,并且每月的日期大于年月的最大值,则将日期调整为每月的最后一天。如果模式是严格的,那么这三个字段必须形成一个有效的日期。YEAR和DAY_OF_YEAR- 如果两者都存在,则将它们组合起来形成一个日期。在所有三种模式中,YEAR都经过验证。如果模式宽松,则日期的组合方式相当于在请求年份的第一天创建一个日期,然后添加天数差异。如果模式是 smart 或 strict,那么这两个字段必须形成一个有效日期。YEAR、MONTH_OF_YEAR、ALIGNED_WEEK_OF_MONTH和ALIGNED_DAY_OF_WEEK_IN_MONTH- 如果所有四个都存在,则将它们组合起来形成一个日期。在所有三种模式中,YEAR都经过验证。如果模式宽松,那么日期的组合方式相当于在所请求年份的第一个月的第一天创建一个日期,然后加上月差,然后是周差,然后是天差。如果模式是智能或严格,则所有四个字段都将验证到它们的外部范围。然后以相当于在请求的年和月的第一天创建日期的方式组合日期,然后添加以周和天为单位的数量以达到它们的值。如果模式是严格的,则会额外验证日期以检查日和周调整是否未更改月份。YEAR、MONTH_OF_YEAR、ALIGNED_WEEK_OF_MONTH和DAY_OF_WEEK- 如果所有四个都存在,则将它们组合起来形成一个日期。该方法与上面在ALIGNED_DAY_OF_WEEK_IN_MONTH中描述的年、月和周相同。处理完年、月和周后,星期几将调整为下一个或相同的匹配星期几。YEAR、ALIGNED_WEEK_OF_YEAR和ALIGNED_DAY_OF_WEEK_IN_YEAR- 如果所有三个都存在,则将它们组合起来形成一个日期。在所有三种模式中,YEAR都经过验证。如果模式宽松,则日期的组合方式相当于在所请求年份的第一天创建一个日期,然后添加以周为单位的差异,然后以天为单位。如果模式是智能或严格,则所有三个字段都将验证到它们的外部范围。然后以相当于在所请求年份的第一天创建一个日期的方式组合日期,然后添加以周和天为单位的数量以达到它们的值。如果模式是严格的,则会额外验证日期以检查日期和星期的调整是否未更改年份。YEAR、ALIGNED_WEEK_OF_YEAR和DAY_OF_WEEK- 如果所有三个都存在,则将它们组合起来形成一个日期。该方法与上面在ALIGNED_DAY_OF_WEEK_IN_YEAR中描述的年和周相同。一旦处理了年和周,星期几就会调整为下一个或相同的匹配星期几。
默认实现适用于大多数日历系统。如果发现
ChronoField.YEAR_OF_ERA没有ChronoField.ERA,则使用Chronology.eras()中的最后一个纪元。该实现假定每周有 7 天,每月的第一天值为 1,每年的第一天值为 1,并且月份和年份的第一天始终存在。- 指定者:
resolveDate在接口Chronology中- 重写:
resolveDate在类AbstractChronology中- 参数:
fieldValues- 字段到值的映射,可以更新,不为空resolverStyle- 请求的解析类型,不为空- 返回:
- 解决日期,如果信息不足以创建日期则为 null
-
isIsoBased
public boolean isIsoBased()- 指定者:
isIsoBased在接口Chronology中- 返回:
true- 自从:
- 19
- 参见:
-