模块 java.base
 java.time

类 LocalDateTime

java.lang.Object
java.time.LocalDateTime
所有已实现的接口:
Serializable , Comparable<ChronoLocalDateTime<?>> , ChronoLocalDateTime<LocalDate> , Temporal , TemporalAccessor , TemporalAdjuster

public final class LocalDateTime extends Object implements Temporal , TemporalAdjuster , ChronoLocalDateTime <LocalDate >, Serializable
ISO-8601 日历系统中没有时区的日期时间,例如 2007-12-03T10:15:30

LocalDateTime 是一个不可变的日期时间对象,表示日期时间,通常被视为年月日时分秒。还可以访问其他日期和时间字段,例如一年中的某一天、星期几和一年中的一周。时间以纳秒精度表示。例如,值“2007 年 10 月 2 日 13:45.30.123456789”可以存储在 LocalDateTime 中。

此类不存储或表示时区。相反,它是对日期的描述,用于生日,结合挂钟上看到的当地时间。如果没有偏移量或时区等附加信息,它不能代表时间线上的一个瞬间。

ISO-8601 日历系统是当今世界大部分地区使用的现代民用日历系统。它相当于公历系统,在所有时间都适用今天的闰年规则。对于当今编写的大多数应用程序,ISO-8601 规则完全适用。然而,任何使用历史日期并要求它们准确的应用程序都会发现 ISO-8601 方法不合适。

这是一个value-based类;程序员应该将 equal 的实例视为可互换的,并且不应使用实例进行同步,否则可能会发生不可预测的行为。例如,在未来的版本中,同步可能会失败。 equals 方法应该用于比较。

实现要求:
这个类是不可变的和线程安全的。
自从:
1.8
参见:
  • 字段详细信息

    • MIN

      public static final LocalDateTime  MIN
      支持的最小值 LocalDateTime,'-999999999-01-01T00:00:00'。这是最小日期开始时的午夜本地日期时间。这结合了 LocalDate.MIN LocalTime.MIN 。这可以被应用程序用作“很久以前”的日期时间。
    • MAX

      public static final LocalDateTime  MAX
      最大支持 LocalDateTime ,'+999999999-12-31T23:59:59.999999999'。这是最大日期结束时午夜之前的本地日期时间。这结合了 LocalDate.MAX LocalTime.MAX 。这可以被应用程序用作“遥远的未来”日期时间。
  • 方法详情

    • now

      public static LocalDateTime  now()
      从默认时区的系统时钟获取当前日期时间。

      这将查询默认时区中的 system clock 以获取当前日期时间。

      使用此方法将阻止使用备用时钟进行测试的能力,因为时钟是硬编码的。

      返回:
      使用系统时钟和默认时区的当前日期时间,不为空
    • now

      public static LocalDateTime  now(ZoneId  zone)
      从指定时区的系统时钟获取当前日期时间。

      这将查询 system clock 以获取当前日期时间。指定时区避免了对默认时区的依赖。

      使用此方法将阻止使用备用时钟进行测试的能力,因为时钟是硬编码的。

      参数:
      zone - 要使用的区域 ID,不为空
      返回:
      使用系统时钟的当前日期时间,不为空
    • now

      public static LocalDateTime  now(Clock  clock)
      从指定时钟获取当前日期时间。

      这将查询指定的时钟以获取当前日期时间。使用此方法允许使用备用时钟进行测试。可以使用 dependency injection 引入备用时钟。

      参数:
      clock - 使用的时钟,不为空
      返回:
      当前日期时间,不为空
    • of

      public static LocalDateTime  of(int year, Month  month, int dayOfMonth, int hour, int minute)
      从年、月、日、小时和分钟中获取 LocalDateTime 的实例,将秒和纳秒设置为零。

      这将返回具有指定年、月、日、小时和分钟的 LocalDateTime。日期必须对年月有效,否则会抛出异常。秒和纳秒字段将设置为零。

      参数:
      year - 表示的年份,从 MIN_YEAR 到 MAX_YEAR
      month - 要表示的月份,不为空
      dayOfMonth - 要表示的日期,从 1 到 31
      hour - 要表示的小时数,从 0 到 23
      minute - 要表示的分钟数,从 0 到 59
      返回:
      本地日期时间,不为空
      抛出:
      DateTimeException - 如果任何字段的值超出范围,或者如果月份日期对于月份年份无效
    • of

      public static LocalDateTime  of(int year, Month  month, int dayOfMonth, int hour, int minute, int second)
      从年、月、日、小时、分钟和秒中获取 LocalDateTime 的实例,将纳秒设置为零。

      这将返回具有指定年、月、日、小时、分钟和秒的 LocalDateTime。日期必须对年月有效,否则会抛出异常。纳秒字段将设置为零。

      参数:
      year - 表示的年份,从 MIN_YEAR 到 MAX_YEAR
      month - 要表示的月份,不为空
      dayOfMonth - 要表示的日期,从 1 到 31
      hour - 要表示的小时数,从 0 到 23
      minute - 要表示的分钟数,从 0 到 59
      second - 表示的秒数,从 0 到 59
      返回:
      本地日期时间,不为空
      抛出:
      DateTimeException - 如果任何字段的值超出范围,或者如果月份日期对于月份年份无效
    • of

      public static LocalDateTime  of(int year, Month  month, int dayOfMonth, int hour, int minute, int second, int nanoOfSecond)
      从年、月、日、小时、分钟、秒和纳秒中获取 LocalDateTime 的实例。

      这将返回具有指定年、月、日、小时、分钟、秒和纳秒的 LocalDateTime。日期必须对年月有效,否则会抛出异常。

      参数:
      year - 表示的年份,从 MIN_YEAR 到 MAX_YEAR
      month - 要表示的月份,不为空
      dayOfMonth - 要表示的日期,从 1 到 31
      hour - 要表示的小时数,从 0 到 23
      minute - 要表示的分钟数,从 0 到 59
      second - 表示的秒数,从 0 到 59
      nanoOfSecond - 表示的纳秒,从 0 到 999,999,999
      返回:
      本地日期时间,不为空
      抛出:
      DateTimeException - 如果任何字段的值超出范围,或者如果月份日期对于月份年份无效
    • of

      public static LocalDateTime  of(int year, int month, int dayOfMonth, int hour, int minute)
      从年、月、日、小时和分钟中获取 LocalDateTime 的实例,将秒和纳秒设置为零。

      这将返回具有指定年、月、日、小时和分钟的 LocalDateTime。日期必须对年月有效,否则会抛出异常。秒和纳秒字段将设置为零。

      参数:
      year - 表示的年份,从 MIN_YEAR 到 MAX_YEAR
      month - 要表示的月份,从 1(一月)到 12(十二月)
      dayOfMonth - 要表示的日期,从 1 到 31
      hour - 要表示的小时数,从 0 到 23
      minute - 要表示的分钟数,从 0 到 59
      返回:
      本地日期时间,不为空
      抛出:
      DateTimeException - 如果任何字段的值超出范围,或者如果月份日期对于月份年份无效
    • of

      public static LocalDateTime  of(int year, int month, int dayOfMonth, int hour, int minute, int second)
      从年、月、日、小时、分钟和秒中获取 LocalDateTime 的实例,将纳秒设置为零。

      这将返回具有指定年、月、日、小时、分钟和秒的 LocalDateTime。日期必须对年月有效,否则会抛出异常。纳秒字段将设置为零。

      参数:
      year - 表示的年份,从 MIN_YEAR 到 MAX_YEAR
      month - 要表示的月份,从 1(一月)到 12(十二月)
      dayOfMonth - 要表示的日期,从 1 到 31
      hour - 要表示的小时数,从 0 到 23
      minute - 要表示的分钟数,从 0 到 59
      second - 表示的秒数,从 0 到 59
      返回:
      本地日期时间,不为空
      抛出:
      DateTimeException - 如果任何字段的值超出范围,或者如果月份日期对于月份年份无效
    • of

      public static LocalDateTime  of(int year, int month, int dayOfMonth, int hour, int minute, int second, int nanoOfSecond)
      从年、月、日、小时、分钟、秒和纳秒中获取 LocalDateTime 的实例。

      这将返回具有指定年、月、日、小时、分钟、秒和纳秒的 LocalDateTime。日期必须对年月有效,否则会抛出异常。

      参数:
      year - 表示的年份,从 MIN_YEAR 到 MAX_YEAR
      month - 要表示的月份,从 1(一月)到 12(十二月)
      dayOfMonth - 要表示的日期,从 1 到 31
      hour - 要表示的小时数,从 0 到 23
      minute - 要表示的分钟数,从 0 到 59
      second - 表示的秒数,从 0 到 59
      nanoOfSecond - 表示的纳秒,从 0 到 999,999,999
      返回:
      本地日期时间,不为空
      抛出:
      DateTimeException - 如果任何字段的值超出范围,或者如果月份日期对于月份年份无效
    • of

      public static LocalDateTime  of(LocalDate  date, LocalTime  time)
      从日期和时间获取 LocalDateTime 的实例。
      参数:
      date - 本地日期,不为空
      time - 当地时间,不为空
      返回:
      本地日期时间,不为空
    • ofInstant

      public static LocalDateTime  ofInstant(Instant  instant, ZoneId  zone)
      Instant 和区域 ID 获取 LocalDateTime 的实例。

      这将根据指定的时刻创建一个本地日期时间。首先,使用区域 ID 和时刻获得与 UTC/格林威治的偏移量,这很简单,因为每个时刻只有一个有效偏移量。然后,即时和偏移量用于计算本地日期时间。

      参数:
      instant - 创建日期时间的时刻,不为空
      zone - 时区,可能是一个偏移量,不为空
      返回:
      本地日期时间,不为空
      抛出:
      DateTimeException - 如果结果超出支持的范围
    • ofEpochSecond

      public static LocalDateTime  ofEpochSecond(long epochSecond, int nanoOfSecond, ZoneOffset  offset)
      使用 1970-01-01T00:00:00Z 纪元的秒数获取 LocalDateTime 的实例。

      这允许将 epoch-second 字段转换为本地日期时间。这主要用于低级转换而不是一般应用程序使用。

      参数:
      epochSecond - 从 1970-01-01T00:00:00Z 开始的秒数
      nanoOfSecond - 秒内的纳秒,从 0 到 999,999,999
      offset - 区域偏移量,不为空
      返回:
      本地日期时间,不为空
      抛出:
      DateTimeException - 如果结果超出支持的范围,或者如果纳秒无效
    • from

      public static LocalDateTime  from(TemporalAccessor  temporal)
      从时间对象中获取 LocalDateTime 的实例。

      这将根据指定的时间获取本地日期时间。 TemporalAccessor 代表一组任意的日期和时间信息,该工厂将其转换为 LocalDateTime 的一个实例。

      转换从时间对象中提取并组合 LocalDateLocalTime。允许实现执行优化,例如访问与相关对象等效的那些字段。

      此方法与功能接口 TemporalQuery 的签名相匹配,允许它通过方法参考 LocalDateTime::from 用作查询。

      参数:
      temporal - 要转换的时间对象,不为空
      返回:
      本地日期时间,不为空
      抛出:
      DateTimeException - 如果无法转换为 LocalDateTime
      参见:
    • parse

      public static LocalDateTime  parse(CharSequence  text)
      2007-12-03T10:15:30 等文本字符串中获取 LocalDateTime 的实例。

      该字符串必须表示有效的日期时间,并使用 DateTimeFormatter.ISO_LOCAL_DATE_TIME 进行解析。

      参数:
      text - 要解析的文本,例如“2007-12-03T10:15:30”,不为空
      返回:
      解析的本地日期时间,不为空
      抛出:
      DateTimeParseException - 如果无法解析文本
    • parse

      public static LocalDateTime  parse(CharSequence  text, DateTimeFormatter  formatter)
      使用特定格式化程序从文本字符串中获取 LocalDateTime 的实例。

      使用格式化程序解析文本,返回日期时间。

      参数:
      text - 要解析的文本,不为空
      formatter - 要使用的格式化程序,不为空
      返回:
      解析的本地日期时间,不为空
      抛出:
      DateTimeParseException - 如果无法解析文本
    • isSupported

      public boolean isSupported(TemporalField  field)
      检查是否支持指定的字段。

      这将检查是否可以针对指定字段查询此日期时间。如果为 false,则调用 range get with(TemporalField, long) 方法将抛出异常。

      如果该字段是一个ChronoField 那么查询就在这里实现。支持的字段是:

      • NANO_OF_SECOND
      • NANO_OF_DAY
      • MICRO_OF_SECOND
      • MICRO_OF_DAY
      • MILLI_OF_SECOND
      • MILLI_OF_DAY
      • SECOND_OF_MINUTE
      • SECOND_OF_DAY
      • MINUTE_OF_HOUR
      • MINUTE_OF_DAY
      • HOUR_OF_AMPM
      • CLOCK_HOUR_OF_AMPM
      • HOUR_OF_DAY
      • CLOCK_HOUR_OF_DAY
      • AMPM_OF_DAY
      • DAY_OF_WEEK
      • ALIGNED_DAY_OF_WEEK_IN_MONTH
      • ALIGNED_DAY_OF_WEEK_IN_YEAR
      • DAY_OF_MONTH
      • DAY_OF_YEAR
      • EPOCH_DAY
      • ALIGNED_WEEK_OF_MONTH
      • ALIGNED_WEEK_OF_YEAR
      • MONTH_OF_YEAR
      • PROLEPTIC_MONTH
      • YEAR_OF_ERA
      • YEAR
      • ERA
      所有其他 ChronoField 实例将返回 false。

      如果该字段不是 ChronoField ,则通过调用 TemporalField.isSupportedBy(TemporalAccessor) 传递 this 作为参数来获得此方法的结果。字段是否支持由字段决定。

      指定者:
      isSupported 在接口 ChronoLocalDateTime<LocalDate>
      指定者:
      isSupported 在接口 TemporalAccessor
      参数:
      field - 要检查的字段,null 返回 false
      返回:
      如果此日期时间支持该字段,则为 true,否则为 false
    • isSupported

      public boolean isSupported(TemporalUnit  unit)
      检查是否支持指定的单位。

      这将检查指定的单位是否可以添加到此日期时间或从中减去。如果为 false,则调用 plus(long, TemporalUnit) minus 方法将抛出异常。

      如果单位是ChronoUnit 那么查询就是在这里实现的。支持的单位有:

      • NANOS
      • MICROS
      • MILLIS
      • SECONDS
      • MINUTES
      • HOURS
      • HALF_DAYS
      • DAYS
      • WEEKS
      • MONTHS
      • YEARS
      • DECADES
      • CENTURIES
      • MILLENNIA
      • ERAS
      所有其他 ChronoUnit 实例将返回 false。

      如果单位不是 ChronoUnit ,则通过调用 TemporalUnit.isSupportedBy(Temporal) 传递 this 作为参数来获得此方法的结果。是否支持该单元由单元决定。

      指定者:
      isSupported 在接口 ChronoLocalDateTime<LocalDate>
      指定者:
      isSupported 在接口 Temporal
      参数:
      unit - 要检查的单位,null 返回 false
      返回:
      如果可以添加/减去单位,则为 true,否则为 false
    • range

      public ValueRange  range(TemporalField  field)
      获取指定字段的有效值范围。

      范围对象表示字段的最小和最大有效值。此日期时间用于提高返回范围的准确性。如果由于不支持该字段或其他原因而无法返回范围,则会抛出异常。

      如果该字段是一个ChronoField 那么查询就在这里实现。 supported fields 将返回适当的范围实例。所有其他 ChronoField 实例将抛出 UnsupportedTemporalTypeException

      如果该字段不是 ChronoField ,则通过调用 TemporalField.rangeRefinedBy(TemporalAccessor) 传递 this 作为参数来获得此方法的结果。能否获取范围由字段决定。

      指定者:
      range 在接口 TemporalAccessor
      参数:
      field - 查询范围的字段,不为空
      返回:
      该字段的有效值范围,不为空
      抛出:
      DateTimeException - 如果无法获得该字段的范围
      UnsupportedTemporalTypeException - 如果不支持该字段
    • get

      public int get(TemporalField  field)
      从此日期时间获取指定字段的值作为 int

      这将在此日期时间查询指定字段的值。返回值将始终在该字段的有效值范围内。如果由于不支持该字段或其他原因而无法返回该值,则会抛出异常。

      如果该字段是一个ChronoField 那么查询就在这里实现。 supported fields 将根据此日期时间返回有效值,但 NANO_OF_DAYMICRO_OF_DAYEPOCH_DAYPROLEPTIC_MONTH 除外,它们太大而无法放入 int 并抛出 UnsupportedTemporalTypeException 。所有其他 ChronoField 实例将抛出 UnsupportedTemporalTypeException

      如果该字段不是 ChronoField ,则通过调用 TemporalField.getFrom(TemporalAccessor) 传递 this 作为参数来获得此方法的结果。能否获取到该值,该值代表什么,由字段决定。

      指定者:
      get 在接口 TemporalAccessor
      参数:
      field - 要获取的字段,不为空
      返回:
      该字段的值
      抛出:
      DateTimeException - 如果无法获取该字段的值或该值超出该字段的有效值范围
      UnsupportedTemporalTypeException - 如果不支持该字段或值的范围超过 int
      ArithmeticException - 如果发生数字溢出
    • getLong

      public long getLong(TemporalField  field)
      从此日期时间获取指定字段的值作为 long

      这将在此日期时间查询指定字段的值。如果由于不支持该字段或其他原因而无法返回该值,则会抛出异常。

      如果该字段是一个ChronoField 那么查询就在这里实现。 supported fields 将根据此日期时间返回有效值。所有其他 ChronoField 实例将抛出 UnsupportedTemporalTypeException

      如果该字段不是 ChronoField ,则通过调用 TemporalField.getFrom(TemporalAccessor) 传递 this 作为参数来获得此方法的结果。能否获取到该值,该值代表什么,由字段决定。

      指定者:
      getLong 在接口 TemporalAccessor
      参数:
      field - 要获取的字段,不为空
      返回:
      该字段的值
      抛出:
      DateTimeException - 如果无法获得该字段的值
      UnsupportedTemporalTypeException - 如果不支持该字段
      ArithmeticException - 如果发生数字溢出
    • toLocalDate

      public LocalDate  toLocalDate()
      获取此日期时间的 LocalDate 部分。

      这将返回与此日期时间具有相同年月日的 LocalDate

      指定者:
      toLocalDate 在接口 ChronoLocalDateTime<LocalDate>
      返回:
      此日期时间的日期部分,不为空
    • getYear

      public int getYear()
      获取年份字段。

      此方法返回年份的原始 int 值。

      根据 get(YEAR),此方法返回的年份是预估的。要获取年代,请使用 get(YEAR_OF_ERA)

      返回:
      年份,从 MIN_YEAR 到 MAX_YEAR
    • getMonthValue

      public int getMonthValue()
      获取从 1 到 12 的月份字段。

      此方法将月份作为 int 从 1 到 12 返回。如果通过调用 getMonth() 使用枚举 Month ,应用程序代码通常会更清晰。

      返回:
      一年中的月份,从 1 到 12
      参见:
    • getMonth

      public Month  getMonth()
      使用 Month 枚举获取月份字段。

      此方法返回月份的枚举 Month 。这避免混淆 int 值的含义。如果您需要访问原始 int 值,则枚举会提供 int value

      返回:
      月份,不为空
      参见:
    • getDayOfMonth

      public int getDayOfMonth()
      获取日期字段。

      此方法返回日期的原始 int 值。

      返回:
      一个月中的第几天,从 1 到 31
    • getDayOfYear

      public int getDayOfYear()
      获取年份字段。

      此方法返回一年中第几天的原始 int 值。

      返回:
      一年中的第几天,从 1 到 365,或闰年为 366
    • getDayOfWeek

      public DayOfWeek  getDayOfWeek()
      获取星期字段,它是一个枚举 DayOfWeek

      此方法返回星期几的枚举 DayOfWeek 。这避免混淆 int 值的含义。如果您需要访问原始 int 值,则枚举会提供 int value

      可以从 DayOfWeek 获得更多信息。这包括值的文本名称。

      返回:
      星期几,不为空
    • toLocalTime

      public LocalTime  toLocalTime()
      获取此日期时间的 LocalTime 部分。

      这将返回一个 LocalTime 与此日期时间具有相同的小时、分钟、秒和纳秒。

      指定者:
      toLocalTime 在接口 ChronoLocalDateTime<LocalDate>
      返回:
      此日期时间的时间部分,不为空
    • getHour

      public int getHour()
      获取一天中的小时字段。
      返回:
      一天中的小时,从 0 到 23
    • getMinute

      public int getMinute()
      获取分钟字段。
      返回:
      小时的分钟数,从 0 到 59
    • getSecond

      public int getSecond()
      获取秒字段。
      返回:
      秒,从 0 到 59
    • getNano

      public int getNano()
      获取纳秒级字段。
      返回:
      纳秒,从 0 到 999,999,999
    • with

      public LocalDateTime  with(TemporalAdjuster  adjuster)
      返回此日期时间的调整副本。

      这将返回一个 LocalDateTime ,基于这个,并调整了日期时间。使用指定的调整器策略对象进行调整。阅读调整器的文档以了解将进行的调整。

      一个简单的调整器可能只是设置其中一个字段,例如年份字段。更复杂的调节器可能会将日期设置为该月的最后一天。

      TemporalAdjusters 中提供了一系列常用调整。其中包括查找“本月的最后一天”和“下周三”。关键日期时间类还实现了 TemporalAdjuster 接口,例如 Month MonthDay 。调节器负责处理特殊情况,例如不同长度的月份和闰年。

      例如,此代码返回 7 月最后一天的日期:

       import static java.time.Month.*;
       import static java.time.temporal.TemporalAdjusters.*;
      
       result = localDateTime.with(JULY).with(lastDayOfMonth());
       

      LocalDate LocalTime 实现 TemporalAdjuster ,因此该方法可用于更改日期、时间或偏移量:

       result = localDateTime.with(date);
       result = localDateTime.with(time);
       

      此方法的结果是通过在指定的调节器上调用 TemporalAdjuster.adjustInto(Temporal) 方法并将 this 作为参数传递来获得的。

      此实例是不可变的,不受此方法调用的影响。

      指定者:
      with 在接口 ChronoLocalDateTime<LocalDate>
      指定者:
      with 在接口 Temporal
      参数:
      adjuster - 要使用的调节器,不为空
      返回:
      LocalDateTime 基于 this 并进行了调整,不为空
      抛出:
      DateTimeException - 如果无法进行调整
      ArithmeticException - 如果发生数字溢出
    • with

      public LocalDateTime  with(TemporalField  field, long newValue)
      返回此日期时间的副本,并将指定字段设置为新值。

      这将返回一个 LocalDateTime ,基于这个,指定字段的值已更改。这可用于更改任何受支持的字段,例如年、月或月中的某天。如果无法设置该值,因为不支持该字段或出于其他原因,则会抛出异常。

      在某些情况下,更改指定字段会导致生成的日期时间无效,例如将月份从 1 月 31 日更改为 2 月会使日期无效。在这种情况下,该字段负责解析日期。通常它会选择之前的有效日期,在本例中为 2 月的最后一个有效日期。

      如果该字段是 ChronoField 则在此处执行调整。 supported fields 将按照 LocalDate LocalTime 上的匹配方法运行。所有其他 ChronoField 实例将抛出 UnsupportedTemporalTypeException

      如果该字段不是 ChronoField ,则通过调用 TemporalField.adjustInto(Temporal, long) 传递 this 作为参数来获得此方法的结果。在这种情况下,该字段决定是否以及如何调整瞬间。

      此实例是不可变的,不受此方法调用的影响。

      指定者:
      with 在接口 ChronoLocalDateTime<LocalDate>
      指定者:
      with 在接口 Temporal
      参数:
      field - 要在结果中设置的字段,不为空
      newValue - 结果中字段的新值
      返回:
      基于 thisLocalDateTime 具有指定的字段集,不为空
      抛出:
      DateTimeException - 如果无法设置字段
      UnsupportedTemporalTypeException - 如果不支持该字段
      ArithmeticException - 如果发生数字溢出
    • withYear

      public LocalDateTime  withYear(int year)
      返回此 LocalDateTime 的副本,并更改年份。

      时间不影响计算,结果相同。如果当年的日期无效,则更改为该月的最后一个有效日期。

      此实例是不可变的,不受此方法调用的影响。

      参数:
      year - 在结果中设置的年份,从 MIN_YEAR 到 MAX_YEAR
      返回:
      LocalDateTime 基于此日期时间和请求的年份,不为空
      抛出:
      DateTimeException - 如果年份值无效
    • withMonth

      public LocalDateTime  withMonth(int month)
      返回此 LocalDateTime 的副本,其中月份已更改。

      时间不影响计算,结果相同。如果当年的日期无效,则更改为该月的最后一个有效日期。

      此实例是不可变的,不受此方法调用的影响。

      参数:
      month - 在结果中设置的月份,从 1(一月)到 12(十二月)
      返回:
      LocalDateTime 基于此日期时间和请求的月份,不为空
      抛出:
      DateTimeException - 如果月份值无效
    • withDayOfMonth

      public LocalDateTime  withDayOfMonth(int dayOfMonth)
      返回此 LocalDateTime 的副本,其中日期已更改。

      如果生成的日期时间无效,则会抛出异常。时间不影响计算,结果相同。

      此实例是不可变的,不受此方法调用的影响。

      参数:
      dayOfMonth - 在结果中设置的日期,从 1 到 28-31
      返回:
      LocalDateTime 基于此日期时间和请求的日期,不为空
      抛出:
      DateTimeException - 如果月日值无效,或者月日对于月年无效
    • withDayOfYear

      public LocalDateTime  withDayOfYear(int dayOfYear)
      返回此 LocalDateTime 的副本,其中日期已更改。

      如果生成的日期时间无效,则会抛出异常。

      此实例是不可变的,不受此方法调用的影响。

      参数:
      dayOfYear - 在结果中设置的日期,从 1 到 365-366
      返回:
      LocalDateTime 基于此日期和请求的日期,不为空
      抛出:
      DateTimeException - 如果年份值无效,或者年份值对于该年无效
    • withHour

      public LocalDateTime  withHour(int hour)
      返回此 LocalDateTime 的副本,其中更改了一天中的小时数。

      此实例是不可变的,不受此方法调用的影响。

      参数:
      hour - 在结果中设置的小时数,从 0 到 23
      返回:
      LocalDateTime 基于此日期时间和请求的时间,不为空
      抛出:
      DateTimeException - 如果小时值无效
    • withMinute

      public LocalDateTime  withMinute(int minute)
      返回此 LocalDateTime 的副本,并更改了分钟。

      此实例是不可变的,不受此方法调用的影响。

      参数:
      minute - 在结果中设置的分钟数,从 0 到 59
      返回:
      LocalDateTime 基于此日期时间和请求的分钟,不为空
      抛出:
      DateTimeException - 如果分钟值无效
    • withSecond

      public LocalDateTime  withSecond(int second)
      返回此 LocalDateTime 的副本,并更改了秒数。

      此实例是不可变的,不受此方法调用的影响。

      参数:
      second - 在结果中设置的秒数,从 0 到 59
      返回:
      LocalDateTime 基于此日期时间和请求的秒数,不为空
      抛出:
      DateTimeException - 如果第二个值无效
    • withNano

      public LocalDateTime  withNano(int nanoOfSecond)
      返回此 LocalDateTime 的副本,并更改了纳秒级。

      此实例是不可变的,不受此方法调用的影响。

      参数:
      nanoOfSecond - 在结果中设置的纳秒,从 0 到 999,999,999
      返回:
      LocalDateTime 基于此日期时间和请求的纳秒,不为空
      抛出:
      DateTimeException - 如果纳米值无效
    • truncatedTo

      public LocalDateTime  truncatedTo(TemporalUnit  unit)
      返回此 LocalDateTime 的副本,时间被截断。

      截断返回原始日期时间的副本,其中小于指定单位的字段设置为零。例如,使用 minutes 单位截断会将秒和纳秒字段设置为零。

      该单位必须有一个 duration,它可以划分为一个标准日的长度,没有余数。这包括 ChronoUnit DAYS 上所有提供的时间单位。其他单位抛出异常。

      此实例是不可变的,不受此方法调用的影响。

      参数:
      unit - 要截断的单位,不为空
      返回:
      LocalDateTime 基于此日期时间,时间被截断,不为空
      抛出:
      DateTimeException - 如果无法截断
      UnsupportedTemporalTypeException - 如果不支持该单元
    • plus

      public LocalDateTime  plus(TemporalAmount  amountToAdd)
      返回添加了指定数量的此日期时间的副本。

      这将返回一个 LocalDateTime ,基于这个,添加了指定的数量。数量通常是 Period Duration 但可以是实现 TemporalAmount 接口的任何其他类型。

      通过调用 TemporalAmount.addTo(Temporal) 将计算委托给金额对象。金额实现可以自由地以任何它希望的方式实现加法,但是它通常会回调 plus(long, TemporalUnit) 。查阅amount实现的文档,判断是否可以添加成功。

      此实例是不可变的,不受此方法调用的影响。

      指定者:
      plus 在接口 ChronoLocalDateTime<LocalDate>
      指定者:
      plus 在接口 Temporal
      参数:
      amountToAdd - 添加的数量,不为空
      返回:
      a LocalDateTime 基于此日期时间并添加,不为空
      抛出:
      DateTimeException - 如果无法添加
      ArithmeticException - 如果发生数字溢出
    • plus

      public LocalDateTime  plus(long amountToAdd, TemporalUnit  unit)
      返回添加了指定数量的此日期时间的副本。

      这将返回一个 LocalDateTime ,基于这个,加上以单位表示的数量。如果由于不支持该单位或其他原因而无法添加金额,则会抛出异常。

      如果该字段是ChronoUnit ,则在此处实现加法。根据 LocalDate.plus(long, TemporalUnit) 添加日期单位。时间单位按照 LocalTime.plus(long, TemporalUnit) 添加,以天为单位添加的任何溢出等同于使用 plusDays(long)

      如果该字段不是 ChronoUnit ,则通过调用 TemporalUnit.addTo(Temporal, long) 传递 this 作为参数来获得此方法的结果。在这种情况下,该单元确定是否以及如何执行加法。

      此实例是不可变的,不受此方法调用的影响。

      指定者:
      plus 在接口 ChronoLocalDateTime<LocalDate>
      指定者:
      plus 在接口 Temporal
      参数:
      amountToAdd - 添加到结果的单位数量,可能为负数
      unit - 添加量的单位,不为空
      返回:
      LocalDateTime 基于此日期时间并添加了指定的数量,不为空
      抛出:
      DateTimeException - 如果无法添加
      UnsupportedTemporalTypeException - 如果不支持该单元
      ArithmeticException - 如果发生数字溢出
    • plusYears

      public LocalDateTime  plusYears(long years)
      返回此 LocalDateTime 的副本,并添加了指定的年数。

      此方法分三步将指定金额添加到年字段:

      1. 将输入年份添加到年份字段
      2. 检查结果日期是否无效
      3. 如有必要,将日期调整为最后一个有效日期

      例如,2008-02-29(闰年)加上一年将导致无效日期 2009-02-29(标准年)。不是返回无效结果,而是选择该月的最后一个有效日期 2009-02-28。

      此实例是不可变的,不受此方法调用的影响。

      参数:
      years - 添加的年份,可能为负
      返回:
      LocalDateTime 基于此日期时间加上年份,不为空
      抛出:
      DateTimeException - 如果结果超出支持的日期范围
    • plusMonths

      public LocalDateTime  plusMonths(long months)
      返回此 LocalDateTime 的副本,其中添加了指定的月数。

      此方法分三步将指定金额添加到月份字段:

      1. 将输入月份添加到月份字段
      2. 检查结果日期是否无效
      3. 如有必要,将日期调整为最后一个有效日期

      例如,2007-03-31 加上一个月将导致无效日期 2007-04-31。不是返回无效结果,而是选择该月的最后一个有效日期 2007-04-30。

      此实例是不可变的,不受此方法调用的影响。

      参数:
      months - 添加的月份,可能为负
      返回:
      LocalDateTime 基于此日期时间加上月份,不为空
      抛出:
      DateTimeException - 如果结果超出支持的日期范围
    • plusWeeks

      public LocalDateTime  plusWeeks(long weeks)
      返回此 LocalDateTime 的副本,并添加了指定的周数。

      此方法将以周为单位的指定数量添加到天数字段,并根据需要递增月份和年份字段,以确保结果保持有效。仅当超过最大/最小年份时,结果才无效。

      例如,2008-12-31 加上一周将得到 2009-01-07。

      此实例是不可变的,不受此方法调用的影响。

      参数:
      weeks - 添加的周数,可能为负数
      返回:
      LocalDateTime 基于此日期时间并添加周数,不为空
      抛出:
      DateTimeException - 如果结果超出支持的日期范围
    • plusDays

      public LocalDateTime  plusDays(long days)
      返回此 LocalDateTime 的副本,并添加了指定的天数。

      此方法将指定的金额添加到天数字段,并根据需要递增月份和年份字段,以确保结果保持有效。仅当超过最大/最小年份时,结果才无效。

      例如,2008-12-31 加上一天将得到 2009-01-01。

      此实例是不可变的,不受此方法调用的影响。

      参数:
      days - 添加的天数,可能是负数
      返回:
      LocalDateTime 基于此日期时间加上天数,不为空
      抛出:
      DateTimeException - 如果结果超出支持的日期范围
    • plusHours

      public LocalDateTime  plusHours(long hours)
      返回此 LocalDateTime 的副本,并添加了指定的小时数。

      此实例是不可变的,不受此方法调用的影响。

      参数:
      hours - 添加的小时数,可能为负数
      返回:
      LocalDateTime 基于此日期时间并添加了小时数,不为空
      抛出:
      DateTimeException - 如果结果超出支持的日期范围
    • plusMinutes

      public LocalDateTime  plusMinutes(long minutes)
      返回此 LocalDateTime 的副本,并添加了指定的分钟数。

      此实例是不可变的,不受此方法调用的影响。

      参数:
      minutes - 添加的分钟数,可能为负数
      返回:
      LocalDateTime 基于此日期时间并添加分钟,不为空
      抛出:
      DateTimeException - 如果结果超出支持的日期范围
    • plusSeconds

      public LocalDateTime  plusSeconds(long seconds)
      返回此 LocalDateTime 的副本,并添加了指定的秒数。

      此实例是不可变的,不受此方法调用的影响。

      参数:
      seconds - 添加的秒数,可能为负
      返回:
      LocalDateTime 基于此日期时间并添加了秒数,不为空
      抛出:
      DateTimeException - 如果结果超出支持的日期范围
    • plusNanos

      public LocalDateTime  plusNanos(long nanos)
      返回此 LocalDateTime 的副本,并添加了指定的纳秒数。

      此实例是不可变的,不受此方法调用的影响。

      参数:
      nanos - 要添加的纳米,可能为负
      返回:
      LocalDateTime 基于此日期时间并添加了纳秒,不为空
      抛出:
      DateTimeException - 如果结果超出支持的日期范围
    • minus

      public LocalDateTime  minus(TemporalAmount  amountToSubtract)
      返回此日期时间的副本,并减去指定的数量。

      这将返回一个 LocalDateTime ,基于这个,减去指定的数量。数量通常是 Period Duration 但可以是实现 TemporalAmount 接口的任何其他类型。

      通过调用 TemporalAmount.subtractFrom(Temporal) 将计算委托给金额对象。金额实现可以自由地以任何它希望的方式实现减法,但是它通常会回调 minus(long, TemporalUnit) 。查阅 amount 实现的文档以确定是否可以成功减去。

      此实例是不可变的,不受此方法调用的影响。

      指定者:
      minus 在接口 ChronoLocalDateTime<LocalDate>
      指定者:
      minus 在接口 Temporal
      参数:
      amountToSubtract - 要减去的金额,不为空
      返回:
      a LocalDateTime 基于这个日期时间减去,不为空
      抛出:
      DateTimeException - 如果无法进行减法
      ArithmeticException - 如果发生数字溢出
    • minus

      public LocalDateTime  minus(long amountToSubtract, TemporalUnit  unit)
      返回此日期时间的副本,并减去指定的数量。

      这将返回一个 LocalDateTime ,基于这个,减去单位数量。如果无法减去金额,因为不支持该单位或出于其他原因,则会抛出异常。

      此方法等同于 plus(long, TemporalUnit) 取反金额。有关加法和减法如何工作的完整描述,请参阅该方法。

      此实例是不可变的,不受此方法调用的影响。

      指定者:
      minus 在接口 ChronoLocalDateTime<LocalDate>
      指定者:
      minus 在接口 Temporal
      参数:
      amountToSubtract - 要从结果中减去的单位数量,可能为负数
      unit - 要减去的金额的单位,不为空
      返回:
      a LocalDateTime 基于此日期时间减去指定的金额,不为空
      抛出:
      DateTimeException - 如果无法进行减法
      UnsupportedTemporalTypeException - 如果不支持该单元
      ArithmeticException - 如果发生数字溢出
    • minusYears

      public LocalDateTime  minusYears(long years)
      返回此 LocalDateTime 的副本,并减去指定的年数。

      此方法分三步从年字段中减去指定的金额:

      1. 从年份字段中减去输入的年份
      2. 检查结果日期是否无效
      3. 如有必要,将日期调整为最后一个有效日期

      例如,2008-02-29(闰年)减去一年将导致无效日期 2007-02-29(标准年)。不是返回无效结果,而是选择该月的最后一个有效日期 2007-02-28。

      此实例是不可变的,不受此方法调用的影响。

      参数:
      years - 要减去的年份,可能为负数
      返回:
      LocalDateTime 基于此日期时间减去年份,不为空
      抛出:
      DateTimeException - 如果结果超出支持的日期范围
    • minusMonths

      public LocalDateTime  minusMonths(long months)
      返回此 LocalDateTime 的副本,并减去指定的月数。

      此方法分三步从月份字段中减去指定的金额:

      1. 从月份字段中减去输入的月份
      2. 检查结果日期是否无效
      3. 如有必要,将日期调整为最后一个有效日期

      例如,2007-03-31 减去一个月将导致无效日期 2007-02-31。不是返回无效结果,而是选择该月的最后一个有效日期 2007-02-28。

      此实例是不可变的,不受此方法调用的影响。

      参数:
      months - 要减去的月份,可能为负数
      返回:
      LocalDateTime 基于此日期时间减去月份,不为空
      抛出:
      DateTimeException - 如果结果超出支持的日期范围
    • minusWeeks

      public LocalDateTime  minusWeeks(long weeks)
      返回此 LocalDateTime 的副本,并减去指定的周数。

      此方法从天字段中减去指定的周数,并根据需要递减月份和年份字段以确保结果保持有效。仅当超过最大/最小年份时,结果才无效。

      例如,2009-01-07 减去一周将得到 2008-12-31。

      此实例是不可变的,不受此方法调用的影响。

      参数:
      weeks - 要减去的周数,可能为负数
      返回:
      LocalDateTime 基于此日期时间减去周数,不为空
      抛出:
      DateTimeException - 如果结果超出支持的日期范围
    • minusDays

      public LocalDateTime  minusDays(long days)
      返回此 LocalDateTime 的副本,并减去指定的天数。

      此方法从天字段中减去指定的金额,并根据需要递减月份和年份字段,以确保结果保持有效。仅当超过最大/最小年份时,结果才无效。

      例如,2009-01-01 减去一天将得到 2008-12-31。

      此实例是不可变的,不受此方法调用的影响。

      参数:
      days - 要减去的天数,可能为负数
      返回:
      LocalDateTime 基于此日期时间减去天数,不为空
      抛出:
      DateTimeException - 如果结果超出支持的日期范围
    • minusHours

      public LocalDateTime  minusHours(long hours)
      返回此 LocalDateTime 的副本,并减去指定的小时数。

      此实例是不可变的,不受此方法调用的影响。

      参数:
      hours - 要减去的小时数,可能为负数
      返回:
      LocalDateTime 基于此日期时间减去小时数,不为空
      抛出:
      DateTimeException - 如果结果超出支持的日期范围
    • minusMinutes

      public LocalDateTime  minusMinutes(long minutes)
      返回此 LocalDateTime 的副本,并减去指定的分钟数。

      此实例是不可变的,不受此方法调用的影响。

      参数:
      minutes - 要减去的分钟数,可能为负数
      返回:
      LocalDateTime 基于此日期时间减去分钟数,不为空
      抛出:
      DateTimeException - 如果结果超出支持的日期范围
    • minusSeconds

      public LocalDateTime  minusSeconds(long seconds)
      返回此 LocalDateTime 的副本,并减去指定的秒数。

      此实例是不可变的,不受此方法调用的影响。

      参数:
      seconds - 减去的秒数,可能为负数
      返回:
      LocalDateTime 基于此日期时间减去秒数,不为空
      抛出:
      DateTimeException - 如果结果超出支持的日期范围
    • minusNanos

      public LocalDateTime  minusNanos(long nanos)
      返回此 LocalDateTime 的副本,并减去指定的纳秒数。

      此实例是不可变的,不受此方法调用的影响。

      参数:
      nanos - 要减去的纳米,可能是负数
      返回:
      LocalDateTime 基于此日期时间减去纳秒,不为空
      抛出:
      DateTimeException - 如果结果超出支持的日期范围
    • query

      public <R> R query(TemporalQuery <R> query)
      使用指定的查询查询此日期时间。

      这使用指定的查询策略对象查询此日期时间。 TemporalQuery 对象定义了用于获取结果的逻辑。阅读查询文档以了解此方法的结果。

      此方法的结果是通过对指定查询调用 TemporalQuery.queryFrom(TemporalAccessor) 方法并将 this 作为参数传递来获得的。

      指定者:
      query 在接口 ChronoLocalDateTime<LocalDate>
      指定者:
      query 在接口 TemporalAccessor
      类型参数:
      R - 结果的类型
      参数:
      query - 要调用的查询,不为空
      返回:
      查询结果,可能返回null(由查询定义)
      抛出:
      DateTimeException - 如果无法查询(由查询定义)
      ArithmeticException - 如果发生数字溢出(由查询定义)
    • adjustInto

      public Temporal  adjustInto(Temporal  temporal)
      调整指定的时态对象,使其具有与该对象相同的日期和时间。

      这将返回一个与输入具有相同可观察类型的时间对象,日期和时间更改为与此相同。

      调整相当于使用了两次Temporal.with(TemporalField, long) ,将ChronoField.EPOCH_DAY ChronoField.NANO_OF_DAY 作为字段传递。

      在大多数情况下,使用 Temporal.with(TemporalAdjuster) 反转调用模式会更清楚:

        // these two lines are equivalent, but the second approach is recommended
        temporal = thisLocalDateTime.adjustInto(temporal);
        temporal = temporal.with(thisLocalDateTime);
       

      此实例是不可变的,不受此方法调用的影响。

      指定者:
      adjustInto 在接口 ChronoLocalDateTime<LocalDate>
      指定者:
      adjustInto 在接口 TemporalAdjuster
      参数:
      temporal - 要调整的目标对象,不为空
      返回:
      调整后的对象,不为空
      抛出:
      DateTimeException - 如果无法进行调整
      ArithmeticException - 如果发生数字溢出
    • until

      public long until(Temporal  endExclusive, TemporalUnit  unit)
      根据指定的单位计算到另一个日期时间的时间量。

      这根据单个 TemporalUnit 计算两个 LocalDateTime 对象之间的时间量。起点和终点是 this 和指定的日期时间。如果结束早于开始,结果将为负。传递给此方法的 Temporal 使用 from(TemporalAccessor) 转换为 LocalDateTime。例如,可以使用 startDateTime.until(endDateTime, DAYS) 计算两个日期时间之间的天数。

      计算返回一个整数,表示两个日期时间之间的完整单位数。例如,2012-06-15T00:00 和 2012-08-14T23:59 之间的月数将只有一个月,因为两个月差一分钟。

      有两种等效的方法可以使用此方法。第一个是调用这个方法。第二种是使用 TemporalUnit.between(Temporal, Temporal)

        // these two lines are equivalent
        amount = start.until(end, MONTHS);
        amount = MONTHS.between(start, end);
       
      应该根据哪个使代码更具可读性来做出选择。

      ChronoUnit 的计算在此方法中实现。单位NANOSMICROSMILLISSECONDSMINUTESHOURSHALF_DAYSDAYSWEEKSMONTHS、支持YEARSDECADESCENTURIESMILLENNIAERAS。其他 ChronoUnit 值将引发异常。

      如果单位不是 ChronoUnit ,则通过调用 TemporalUnit.between(Temporal, Temporal)this 作为第一个参数并将转换后的输入时间作为第二个参数来获得此方法的结果。

      此实例是不可变的,不受此方法调用的影响。

      指定者:
      until 在接口 Temporal
      参数:
      endExclusive - 结束日期,独占,转换为 LocalDateTime ,不为空
      unit - 衡量数量的单位,不为空
      返回:
      此日期时间和结束日期时间之间的时间量
      抛出:
      DateTimeException - 如果无法计算数量,或者结束时间无法转换为 LocalDateTime
      UnsupportedTemporalTypeException - 如果不支持该单元
      ArithmeticException - 如果发生数字溢出
    • format

      public String  format(DateTimeFormatter  formatter)
      使用指定的格式化程序格式化此日期时间。

      此日期时间将传递给格式化程序以生成字符串。

      指定者:
      format 在接口 ChronoLocalDateTime<LocalDate>
      参数:
      formatter - 要使用的格式化程序,不为空
      返回:
      格式化的日期时间字符串,不为空
      抛出:
      DateTimeException - 如果在打印过程中发生错误
    • atOffset

      public OffsetDateTime  atOffset(ZoneOffset  offset)
      将此日期时间与偏移量组合以创建 OffsetDateTime

      这将返回一个 OffsetDateTime 从该日期时间在指定的偏移量处形成。日期时间和偏移量的所有可能组合均有效。

      参数:
      offset - 要结合的偏移量,不为空
      返回:
      从此日期时间和指定的偏移量形成的偏移量日期时间,不为空
    • atZone

      public ZonedDateTime  atZone(ZoneId  zone)
      将此日期时间与时区组合以创建 ZonedDateTime

      这将返回在指定时区从该日期时间形成的 ZonedDateTime。结果将尽可能匹配此日期时间。时区规则,例如夏令时,意味着并非每个本地日期时间都对指定区域有效,因此可以调整本地日期时间。

      本地日期时间被解析为时间线上的单个瞬间。这是通过为由区域 ID 的 rules 定义的本地日期时间找到与 UTC/格林威治的有效偏移量来实现的。

      在大多数情况下,本地日期时间只有一个有效偏移量。在重叠的情况下,时钟向后设置,有两个有效的偏移量。此方法使用通常对应于“夏季”的较早偏移量。

      在间隙的情况下,时钟向前跳跃,没有有效的偏移量。相反,本地日期时间被调整为较晚的间隔长度。对于典型的一小时夏令时更改,本地日期时间将在一小时后移动到通常对应于“夏季”的偏移量中。

      要在重叠期间获得后来的偏移量,请对此方法的结果调用 ZonedDateTime.withLaterOffsetAtOverlap() 。要在存在间隙或重叠时抛出异常,请使用 ZonedDateTime.ofStrict(LocalDateTime, ZoneOffset, ZoneId)

      指定者:
      atZone 在接口 ChronoLocalDateTime<LocalDate>
      参数:
      zone - 要使用的时区,不为空
      返回:
      从此日期时间形成的分区日期时间,不为空
    • compareTo

      public int compareTo(ChronoLocalDateTime <?> other)
      将此日期时间与另一个日期时间进行比较。

      比较主要基于日期时间,从最早到最晚。正如 Comparable 所定义的那样,它“与等于一致”。

      如果所有被比较的日期时间都是 LocalDateTime 的实例,那么比较将完全基于日期时间。如果比较的某些日期处于不同的年表中,那么也会考虑年表,请参阅 ChronoLocalDateTime.compareTo(java.time.chrono.ChronoLocalDateTime<?>)

      指定者:
      compareTo 在接口 ChronoLocalDateTime<LocalDate>
      指定者:
      compareTo 在接口 Comparable<ChronoLocalDateTime<?>>
      参数:
      other - 要比较的另一个日期时间,不为空
      返回:
      比较值,小于则为负,大于则为正
    • isAfter

      public boolean isAfter(ChronoLocalDateTime <?> other)
      检查此日期时间是否在指定的日期时间之后。

      这将检查此日期时间是否代表本地时间线上另一个日期时间之后的一个点。

        LocalDate a = LocalDateTime.of(2012, 6, 30, 12, 00);
        LocalDate b = LocalDateTime.of(2012, 7, 1, 12, 00);
        a.isAfter(b) == false
        a.isAfter(a) == false
        b.isAfter(a) == true
       

      此方法仅考虑两个日期时间在本地时间线上的位置。它不考虑年表或日历系统。这与 compareTo(ChronoLocalDateTime) 中的比较不同,但与 ChronoLocalDateTime.timeLineOrder() 中的方法相同。

      指定者:
      isAfter 在接口 ChronoLocalDateTime<LocalDate>
      参数:
      other - 要比较的另一个日期时间,不为空
      返回:
      如果此日期时间晚于指定的日期时间,则为真
    • isBefore

      public boolean isBefore(ChronoLocalDateTime <?> other)
      检查此日期时间是否早于指定的日期时间。

      这将检查此日期时间是否代表本地时间线上另一个日期时间之前的一个点。

        LocalDate a = LocalDateTime.of(2012, 6, 30, 12, 00);
        LocalDate b = LocalDateTime.of(2012, 7, 1, 12, 00);
        a.isBefore(b) == true
        a.isBefore(a) == false
        b.isBefore(a) == false
       

      此方法仅考虑两个日期时间在本地时间线上的位置。它不考虑年表或日历系统。这与 compareTo(ChronoLocalDateTime) 中的比较不同,但与 ChronoLocalDateTime.timeLineOrder() 中的方法相同。

      指定者:
      isBefore 在接口 ChronoLocalDateTime<LocalDate>
      参数:
      other - 要比较的另一个日期时间,不为空
      返回:
      如果此日期时间早于指定的日期时间,则为真
    • isEqual

      public boolean isEqual(ChronoLocalDateTime <?> other)
      检查此日期时间是否等于指定的日期时间。

      这将检查此日期时间是否表示本地时间线上与其他日期时间相同的点。

        LocalDate a = LocalDateTime.of(2012, 6, 30, 12, 00);
        LocalDate b = LocalDateTime.of(2012, 7, 1, 12, 00);
        a.isEqual(b) == false
        a.isEqual(a) == true
        b.isEqual(a) == false
       

      此方法仅考虑两个日期时间在本地时间线上的位置。它不考虑年表或日历系统。这与 compareTo(ChronoLocalDateTime) 中的比较不同,但与 ChronoLocalDateTime.timeLineOrder() 中的方法相同。

      指定者:
      isEqual 在接口 ChronoLocalDateTime<LocalDate>
      参数:
      other - 要比较的另一个日期时间,不为空
      返回:
      如果此日期时间等于指定的日期时间,则为真
    • equals

      public boolean equals(Object  obj)
      检查此日期时间是否等于另一个日期时间。

      将此 LocalDateTime 与另一个进行比较,确保日期时间相同。只比较 LocalDateTime 类型的对象,其他类型返回 false。

      指定者:
      equals 在接口 ChronoLocalDateTime<LocalDate>
      重写:
      equals 在类 Object
      参数:
      obj - 要检查的对象,null 返回 false
      返回:
      如果这等于另一个日期时间,则为真
      参见:
    • hashCode

      public int hashCode()
      此日期时间的哈希码。
      指定者:
      hashCode 在接口 ChronoLocalDateTime<LocalDate>
      重写:
      hashCode 在类 Object
      返回:
      合适的哈希码
      参见:
    • toString

      public String  toString()
      将此日期时间输出为 String ,例如 2007-12-03T10:15:30

      输出将是以下 ISO-8601 格式之一:

      • uuuu-MM-dd'T'HH:mm
      • uuuu-MM-dd'T'HH:mm:ss
      • uuuu-MM-dd'T'HH:mm:ss.SSS
      • uuuu-MM-dd'T'HH:mm:ss.SSSSSS
      • uuuu-MM-dd'T'HH:mm:ss.SSSSSSSSS
      使用的格式将是输出时间的完整值的最短格式,其中省略的部分隐含为零。
      指定者:
      toString 在接口 ChronoLocalDateTime<LocalDate>
      重写:
      toString 在类 Object
      返回:
      此日期时间的字符串表示形式,不为空