- 所有已实现的接口:
Serializable,Comparable<ChronoLocalDateTime<?>>,ChronoLocalDateTime<LocalDate>,Temporal,TemporalAccessor,TemporalAdjuster
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
- 参见:
-
字段摘要
字段修饰符和类型Field描述static final LocalDateTime最大支持LocalDateTime,'+999999999-12-31T23:59:59.999999999'。static final LocalDateTime支持的最小值LocalDateTime,'-999999999-01-01T00:00:00'。 -
方法总结
修饰符和类型方法描述adjustInto(Temporal temporal) 调整指定的时态对象,使其具有与该对象相同的日期和时间。atOffset(ZoneOffset offset) 将此日期时间与偏移量组合以创建OffsetDateTime。将此日期时间与时区组合以创建ZonedDateTime。intcompareTo(ChronoLocalDateTime<?> other) 将此日期时间与另一个日期时间进行比较。boolean检查此日期时间是否等于另一个日期时间。format(DateTimeFormatter formatter) 使用指定的格式化程序格式化此日期时间。static LocalDateTimefrom(TemporalAccessor temporal) 从时间对象中获取LocalDateTime的实例。intget(TemporalField field) 从此日期时间获取指定字段的值作为int。int获取日期字段。获取星期字段,它是一个枚举DayOfWeek。int获取年份字段。intgetHour()获取一天中的小时字段。longgetLong(TemporalField field) 从此日期时间获取指定字段的值作为long。int获取分钟字段。getMonth()使用Month枚举获取月份字段。int获取从 1 到 12 的月份字段。intgetNano()获取纳秒级字段。int获取秒字段。intgetYear()获取年份字段。inthashCode()此日期时间的哈希码。booleanisAfter(ChronoLocalDateTime<?> other) 检查此日期时间是否在指定的日期时间之后。booleanisBefore(ChronoLocalDateTime<?> other) 检查此日期时间是否早于指定的日期时间。booleanisEqual(ChronoLocalDateTime<?> other) 检查此日期时间是否等于指定的日期时间。booleanisSupported(TemporalField field) 检查是否支持指定的字段。booleanisSupported(TemporalUnit unit) 检查是否支持指定的单位。minus(long amountToSubtract, TemporalUnit unit) 返回此日期时间的副本,并减去指定的数量。minus(TemporalAmount amountToSubtract) 返回此日期时间的副本,并减去指定的数量。minusDays(long days) 返回此LocalDateTime的副本,并减去指定的天数。minusHours(long hours) 返回此LocalDateTime的副本,并减去指定的小时数。minusMinutes(long minutes) 返回此LocalDateTime的副本,并减去指定的分钟数。minusMonths(long months) 返回此LocalDateTime的副本,并减去指定的月数。minusNanos(long nanos) 返回此LocalDateTime的副本,并减去指定的纳秒数。minusSeconds(long seconds) 返回此LocalDateTime的副本,并减去指定的秒数。minusWeeks(long weeks) 返回此LocalDateTime的副本,并减去指定的周数。minusYears(long years) 返回此LocalDateTime的副本,并减去指定的年数。static LocalDateTimenow()从默认时区的系统时钟获取当前日期时间。static LocalDateTime从指定时钟获取当前日期时间。static LocalDateTime从指定时区的系统时钟获取当前日期时间。static LocalDateTimeof(int year, int month, int dayOfMonth, int hour, int minute) 从年、月、日、小时和分钟中获取LocalDateTime的实例,将秒和纳秒设置为零。static LocalDateTimeof(int year, int month, int dayOfMonth, int hour, int minute, int second) 从年、月、日、小时、分钟和秒中获取LocalDateTime的实例,将纳秒设置为零。static LocalDateTimeof(int year, int month, int dayOfMonth, int hour, int minute, int second, int nanoOfSecond) 从年、月、日、小时、分钟、秒和纳秒中获取LocalDateTime的实例。static LocalDateTime从年、月、日、小时和分钟中获取LocalDateTime的实例,将秒和纳秒设置为零。static LocalDateTime从年、月、日、小时、分钟和秒中获取LocalDateTime的实例,将纳秒设置为零。static LocalDateTime从年、月、日、小时、分钟、秒和纳秒中获取LocalDateTime的实例。static LocalDateTime从日期和时间获取LocalDateTime的实例。static LocalDateTimeofEpochSecond(long epochSecond, int nanoOfSecond, ZoneOffset offset) 使用 1970-01-01T00:00:00Z 纪元的秒数获取LocalDateTime的实例。static LocalDateTime从Instant和区域 ID 获取LocalDateTime的实例。static LocalDateTimeparse(CharSequence text) 从2007-12-03T10:15:30等文本字符串中获取LocalDateTime的实例。static LocalDateTimeparse(CharSequence text, DateTimeFormatter formatter) 使用特定格式化程序从文本字符串中获取LocalDateTime的实例。plus(long amountToAdd, TemporalUnit unit) 返回添加了指定数量的此日期时间的副本。plus(TemporalAmount amountToAdd) 返回添加了指定数量的此日期时间的副本。plusDays(long days) 返回此LocalDateTime的副本,并添加了指定的天数。plusHours(long hours) 返回此LocalDateTime的副本,并添加了指定的小时数。plusMinutes(long minutes) 返回此LocalDateTime的副本,并添加了指定的分钟数。plusMonths(long months) 返回此LocalDateTime的副本,其中添加了指定的月数。plusNanos(long nanos) 返回此LocalDateTime的副本,并添加了指定的纳秒数。plusSeconds(long seconds) 返回此LocalDateTime的副本,并添加了指定的秒数。plusWeeks(long weeks) 返回此LocalDateTime的副本,并添加了指定的周数。plusYears(long years) 返回此LocalDateTime的副本,并添加了指定的年数。<R> Rquery(TemporalQuery<R> query) 使用指定的查询查询此日期时间。range(TemporalField field) 获取指定字段的有效值范围。获取此日期时间的LocalDate部分。获取此日期时间的LocalTime部分。toString()将此日期时间输出为String,例如2007-12-03T10:15:30。truncatedTo(TemporalUnit unit) 返回此LocalDateTime的副本,时间被截断。longuntil(Temporal endExclusive, TemporalUnit unit) 根据指定的单位计算到另一个日期时间的时间量。with(TemporalAdjuster adjuster) 返回此日期时间的调整副本。with(TemporalField field, long newValue) 返回此日期时间的副本,并将指定字段设置为新值。withDayOfMonth(int dayOfMonth) 返回此LocalDateTime的副本,其中日期已更改。withDayOfYear(int dayOfYear) 返回此LocalDateTime的副本,其中日期已更改。withHour(int hour) 返回此LocalDateTime的副本,其中更改了一天中的小时数。withMinute(int minute) 返回此LocalDateTime的副本,并更改了分钟。withMonth(int month) 返回此LocalDateTime的副本,其中月份已更改。withNano(int nanoOfSecond) 返回此LocalDateTime的副本,并更改了纳秒级。withSecond(int second) 返回此LocalDateTime的副本,并更改了秒数。withYear(int year) 返回此LocalDateTime的副本,并更改年份。在接口 java.time.chrono.ChronoLocalDateTime 中声明的方法
getChronology, toEpochSecond, toInstant
-
字段详细信息
-
MIN
支持的最小值LocalDateTime,'-999999999-01-01T00:00:00'。这是最小日期开始时的午夜本地日期时间。这结合了LocalDate.MIN和LocalTime.MIN。这可以被应用程序用作“很久以前”的日期时间。 -
MAX
最大支持LocalDateTime,'+999999999-12-31T23:59:59.999999999'。这是最大日期结束时午夜之前的本地日期时间。这结合了LocalDate.MAX和LocalTime.MAX。这可以被应用程序用作“遥远的未来”日期时间。
-
-
方法详情
-
now
从默认时区的系统时钟获取当前日期时间。这将查询默认时区中的
system clock以获取当前日期时间。使用此方法将阻止使用备用时钟进行测试的能力,因为时钟是硬编码的。
- 返回:
- 使用系统时钟和默认时区的当前日期时间,不为空
-
now
从指定时区的系统时钟获取当前日期时间。这将查询
system clock以获取当前日期时间。指定时区避免了对默认时区的依赖。使用此方法将阻止使用备用时钟进行测试的能力,因为时钟是硬编码的。
- 参数:
zone- 要使用的区域 ID,不为空- 返回:
- 使用系统时钟的当前日期时间,不为空
-
now
从指定时钟获取当前日期时间。这将查询指定的时钟以获取当前日期时间。使用此方法允许使用备用时钟进行测试。可以使用
dependency injection引入备用时钟。- 参数:
clock- 使用的时钟,不为空- 返回:
- 当前日期时间,不为空
-
of
从年、月、日、小时和分钟中获取LocalDateTime的实例,将秒和纳秒设置为零。这将返回具有指定年、月、日、小时和分钟的
LocalDateTime。日期必须对年月有效,否则会抛出异常。秒和纳秒字段将设置为零。- 参数:
year- 表示的年份,从 MIN_YEAR 到 MAX_YEARmonth- 要表示的月份,不为空dayOfMonth- 要表示的日期,从 1 到 31hour- 要表示的小时数,从 0 到 23minute- 要表示的分钟数,从 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_YEARmonth- 要表示的月份,不为空dayOfMonth- 要表示的日期,从 1 到 31hour- 要表示的小时数,从 0 到 23minute- 要表示的分钟数,从 0 到 59second- 表示的秒数,从 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_YEARmonth- 要表示的月份,不为空dayOfMonth- 要表示的日期,从 1 到 31hour- 要表示的小时数,从 0 到 23minute- 要表示的分钟数,从 0 到 59second- 表示的秒数,从 0 到 59nanoOfSecond- 表示的纳秒,从 0 到 999,999,999- 返回:
- 本地日期时间,不为空
- 抛出:
DateTimeException- 如果任何字段的值超出范围,或者如果月份日期对于月份年份无效
-
of
从年、月、日、小时和分钟中获取LocalDateTime的实例,将秒和纳秒设置为零。这将返回具有指定年、月、日、小时和分钟的
LocalDateTime。日期必须对年月有效,否则会抛出异常。秒和纳秒字段将设置为零。- 参数:
year- 表示的年份,从 MIN_YEAR 到 MAX_YEARmonth- 要表示的月份,从 1(一月)到 12(十二月)dayOfMonth- 要表示的日期,从 1 到 31hour- 要表示的小时数,从 0 到 23minute- 要表示的分钟数,从 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_YEARmonth- 要表示的月份,从 1(一月)到 12(十二月)dayOfMonth- 要表示的日期,从 1 到 31hour- 要表示的小时数,从 0 到 23minute- 要表示的分钟数,从 0 到 59second- 表示的秒数,从 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_YEARmonth- 要表示的月份,从 1(一月)到 12(十二月)dayOfMonth- 要表示的日期,从 1 到 31hour- 要表示的小时数,从 0 到 23minute- 要表示的分钟数,从 0 到 59second- 表示的秒数,从 0 到 59nanoOfSecond- 表示的纳秒,从 0 到 999,999,999- 返回:
- 本地日期时间,不为空
- 抛出:
DateTimeException- 如果任何字段的值超出范围,或者如果月份日期对于月份年份无效
-
of
从日期和时间获取LocalDateTime的实例。- 参数:
date- 本地日期,不为空time- 当地时间,不为空- 返回:
- 本地日期时间,不为空
-
ofInstant
从Instant和区域 ID 获取LocalDateTime的实例。这将根据指定的时刻创建一个本地日期时间。首先,使用区域 ID 和时刻获得与 UTC/格林威治的偏移量,这很简单,因为每个时刻只有一个有效偏移量。然后,即时和偏移量用于计算本地日期时间。
- 参数:
instant- 创建日期时间的时刻,不为空zone- 时区,可能是一个偏移量,不为空- 返回:
- 本地日期时间,不为空
- 抛出:
DateTimeException- 如果结果超出支持的范围
-
ofEpochSecond
使用 1970-01-01T00:00:00Z 纪元的秒数获取LocalDateTime的实例。这允许将
epoch-second字段转换为本地日期时间。这主要用于低级转换而不是一般应用程序使用。- 参数:
epochSecond- 从 1970-01-01T00:00:00Z 开始的秒数nanoOfSecond- 秒内的纳秒,从 0 到 999,999,999offset- 区域偏移量,不为空- 返回:
- 本地日期时间,不为空
- 抛出:
DateTimeException- 如果结果超出支持的范围,或者如果纳秒无效
-
from
从时间对象中获取LocalDateTime的实例。这将根据指定的时间获取本地日期时间。
TemporalAccessor代表一组任意的日期和时间信息,该工厂将其转换为LocalDateTime的一个实例。转换从时间对象中提取并组合
LocalDate和LocalTime。允许实现执行优化,例如访问与相关对象等效的那些字段。此方法与功能接口
TemporalQuery的签名相匹配,允许它通过方法参考LocalDateTime::from用作查询。- 参数:
temporal- 要转换的时间对象,不为空- 返回:
- 本地日期时间,不为空
- 抛出:
DateTimeException- 如果无法转换为LocalDateTime- 参见:
-
parse
从2007-12-03T10:15:30等文本字符串中获取LocalDateTime的实例。该字符串必须表示有效的日期时间,并使用
DateTimeFormatter.ISO_LOCAL_DATE_TIME进行解析。- 参数:
text- 要解析的文本,例如“2007-12-03T10:15:30”,不为空- 返回:
- 解析的本地日期时间,不为空
- 抛出:
DateTimeParseException- 如果无法解析文本
-
parse
使用特定格式化程序从文本字符串中获取LocalDateTime的实例。使用格式化程序解析文本,返回日期时间。
- 参数:
text- 要解析的文本,不为空formatter- 要使用的格式化程序,不为空- 返回:
- 解析的本地日期时间,不为空
- 抛出:
DateTimeParseException- 如果无法解析文本
-
isSupported
检查是否支持指定的字段。这将检查是否可以针对指定字段查询此日期时间。如果为 false,则调用
range、get和with(TemporalField, long)方法将抛出异常。如果该字段是一个
ChronoField那么查询就在这里实现。支持的字段是:NANO_OF_SECONDNANO_OF_DAYMICRO_OF_SECONDMICRO_OF_DAYMILLI_OF_SECONDMILLI_OF_DAYSECOND_OF_MINUTESECOND_OF_DAYMINUTE_OF_HOURMINUTE_OF_DAYHOUR_OF_AMPMCLOCK_HOUR_OF_AMPMHOUR_OF_DAYCLOCK_HOUR_OF_DAYAMPM_OF_DAYDAY_OF_WEEKALIGNED_DAY_OF_WEEK_IN_MONTHALIGNED_DAY_OF_WEEK_IN_YEARDAY_OF_MONTHDAY_OF_YEAREPOCH_DAYALIGNED_WEEK_OF_MONTHALIGNED_WEEK_OF_YEARMONTH_OF_YEARPROLEPTIC_MONTHYEAR_OF_ERAYEARERA
ChronoField实例将返回 false。如果该字段不是
ChronoField,则通过调用TemporalField.isSupportedBy(TemporalAccessor)传递this作为参数来获得此方法的结果。字段是否支持由字段决定。- 指定者:
isSupported在接口ChronoLocalDateTime<LocalDate>中- 指定者:
isSupported在接口TemporalAccessor中- 参数:
field- 要检查的字段,null 返回 false- 返回:
- 如果此日期时间支持该字段,则为 true,否则为 false
-
isSupported
检查是否支持指定的单位。这将检查指定的单位是否可以添加到此日期时间或从中减去。如果为 false,则调用
plus(long, TemporalUnit)和minus方法将抛出异常。如果单位是
ChronoUnit那么查询就是在这里实现的。支持的单位有:NANOSMICROSMILLISSECONDSMINUTESHOURSHALF_DAYSDAYSWEEKSMONTHSYEARSDECADESCENTURIESMILLENNIAERAS
ChronoUnit实例将返回 false。如果单位不是
ChronoUnit,则通过调用TemporalUnit.isSupportedBy(Temporal)传递this作为参数来获得此方法的结果。是否支持该单元由单元决定。- 指定者:
isSupported在接口ChronoLocalDateTime<LocalDate>中- 指定者:
isSupported在接口Temporal中- 参数:
unit- 要检查的单位,null 返回 false- 返回:
- 如果可以添加/减去单位,则为 true,否则为 false
-
range
获取指定字段的有效值范围。范围对象表示字段的最小和最大有效值。此日期时间用于提高返回范围的准确性。如果由于不支持该字段或其他原因而无法返回范围,则会抛出异常。
如果该字段是一个
ChronoField那么查询就在这里实现。supported fields将返回适当的范围实例。所有其他ChronoField实例将抛出UnsupportedTemporalTypeException。如果该字段不是
ChronoField,则通过调用TemporalField.rangeRefinedBy(TemporalAccessor)传递this作为参数来获得此方法的结果。能否获取范围由字段决定。- 指定者:
range在接口TemporalAccessor中- 参数:
field- 查询范围的字段,不为空- 返回:
- 该字段的有效值范围,不为空
- 抛出:
DateTimeException- 如果无法获得该字段的范围UnsupportedTemporalTypeException- 如果不支持该字段
-
get
从此日期时间获取指定字段的值作为int。这将在此日期时间查询指定字段的值。返回值将始终在该字段的有效值范围内。如果由于不支持该字段或其他原因而无法返回该值,则会抛出异常。
如果该字段是一个
ChronoField那么查询就在这里实现。supported fields将根据此日期时间返回有效值,但NANO_OF_DAY、MICRO_OF_DAY、EPOCH_DAY和PROLEPTIC_MONTH除外,它们太大而无法放入int并抛出UnsupportedTemporalTypeException。所有其他ChronoField实例将抛出UnsupportedTemporalTypeException。如果该字段不是
ChronoField,则通过调用TemporalField.getFrom(TemporalAccessor)传递this作为参数来获得此方法的结果。能否获取到该值,该值代表什么,由字段决定。- 指定者:
get在接口TemporalAccessor中- 参数:
field- 要获取的字段,不为空- 返回:
- 该字段的值
- 抛出:
DateTimeException- 如果无法获取该字段的值或该值超出该字段的有效值范围UnsupportedTemporalTypeException- 如果不支持该字段或值的范围超过intArithmeticException- 如果发生数字溢出
-
getLong
从此日期时间获取指定字段的值作为long。这将在此日期时间查询指定字段的值。如果由于不支持该字段或其他原因而无法返回该值,则会抛出异常。
如果该字段是一个
ChronoField那么查询就在这里实现。supported fields将根据此日期时间返回有效值。所有其他ChronoField实例将抛出UnsupportedTemporalTypeException。如果该字段不是
ChronoField,则通过调用TemporalField.getFrom(TemporalAccessor)传递this作为参数来获得此方法的结果。能否获取到该值,该值代表什么,由字段决定。- 指定者:
getLong在接口TemporalAccessor中- 参数:
field- 要获取的字段,不为空- 返回:
- 该字段的值
- 抛出:
DateTimeException- 如果无法获得该字段的值UnsupportedTemporalTypeException- 如果不支持该字段ArithmeticException- 如果发生数字溢出
-
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
- 返回:
- 月份,不为空
- 参见:
-
getDayOfMonth
public int getDayOfMonth()获取日期字段。此方法返回日期的原始
int值。- 返回:
- 一个月中的第几天,从 1 到 31
-
getDayOfYear
public int getDayOfYear()获取年份字段。此方法返回一年中第几天的原始
int值。- 返回:
- 一年中的第几天,从 1 到 365,或闰年为 366
-
getDayOfWeek
获取星期字段,它是一个枚举DayOfWeek。此方法返回星期几的枚举
DayOfWeek。这避免混淆int值的含义。如果您需要访问原始int值,则枚举会提供int value。可以从
DayOfWeek获得更多信息。这包括值的文本名称。- 返回:
- 星期几,不为空
-
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
返回此日期时间的调整副本。这将返回一个
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
返回此日期时间的副本,并将指定字段设置为新值。这将返回一个
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- 结果中字段的新值- 返回:
-
基于
this的LocalDateTime具有指定的字段集,不为空 - 抛出:
DateTimeException- 如果无法设置字段UnsupportedTemporalTypeException- 如果不支持该字段ArithmeticException- 如果发生数字溢出
-
withYear
返回此LocalDateTime的副本,并更改年份。时间不影响计算,结果相同。如果当年的日期无效,则更改为该月的最后一个有效日期。
此实例是不可变的,不受此方法调用的影响。
- 参数:
year- 在结果中设置的年份,从 MIN_YEAR 到 MAX_YEAR- 返回:
LocalDateTime基于此日期时间和请求的年份,不为空- 抛出:
DateTimeException- 如果年份值无效
-
withMonth
返回此LocalDateTime的副本,其中月份已更改。时间不影响计算,结果相同。如果当年的日期无效,则更改为该月的最后一个有效日期。
此实例是不可变的,不受此方法调用的影响。
- 参数:
month- 在结果中设置的月份,从 1(一月)到 12(十二月)- 返回:
LocalDateTime基于此日期时间和请求的月份,不为空- 抛出:
DateTimeException- 如果月份值无效
-
withDayOfMonth
返回此LocalDateTime的副本,其中日期已更改。如果生成的日期时间无效,则会抛出异常。时间不影响计算,结果相同。
此实例是不可变的,不受此方法调用的影响。
- 参数:
dayOfMonth- 在结果中设置的日期,从 1 到 28-31- 返回:
LocalDateTime基于此日期时间和请求的日期,不为空- 抛出:
DateTimeException- 如果月日值无效,或者月日对于月年无效
-
withDayOfYear
返回此LocalDateTime的副本,其中日期已更改。如果生成的日期时间无效,则会抛出异常。
此实例是不可变的,不受此方法调用的影响。
- 参数:
dayOfYear- 在结果中设置的日期,从 1 到 365-366- 返回:
LocalDateTime基于此日期和请求的日期,不为空- 抛出:
DateTimeException- 如果年份值无效,或者年份值对于该年无效
-
withHour
返回此LocalDateTime的副本,其中更改了一天中的小时数。此实例是不可变的,不受此方法调用的影响。
- 参数:
hour- 在结果中设置的小时数,从 0 到 23- 返回:
LocalDateTime基于此日期时间和请求的时间,不为空- 抛出:
DateTimeException- 如果小时值无效
-
withMinute
返回此LocalDateTime的副本,并更改了分钟。此实例是不可变的,不受此方法调用的影响。
- 参数:
minute- 在结果中设置的分钟数,从 0 到 59- 返回:
LocalDateTime基于此日期时间和请求的分钟,不为空- 抛出:
DateTimeException- 如果分钟值无效
-
withSecond
返回此LocalDateTime的副本,并更改了秒数。此实例是不可变的,不受此方法调用的影响。
- 参数:
second- 在结果中设置的秒数,从 0 到 59- 返回:
LocalDateTime基于此日期时间和请求的秒数,不为空- 抛出:
DateTimeException- 如果第二个值无效
-
withNano
返回此LocalDateTime的副本,并更改了纳秒级。此实例是不可变的,不受此方法调用的影响。
- 参数:
nanoOfSecond- 在结果中设置的纳秒,从 0 到 999,999,999- 返回:
LocalDateTime基于此日期时间和请求的纳秒,不为空- 抛出:
DateTimeException- 如果纳米值无效
-
truncatedTo
返回此LocalDateTime的副本,时间被截断。截断返回原始日期时间的副本,其中小于指定单位的字段设置为零。例如,使用
minutes单位截断会将秒和纳秒字段设置为零。该单位必须有一个 duration,它可以划分为一个标准日的长度,没有余数。这包括
ChronoUnit和DAYS上所有提供的时间单位。其他单位抛出异常。此实例是不可变的,不受此方法调用的影响。
- 参数:
unit- 要截断的单位,不为空- 返回:
LocalDateTime基于此日期时间,时间被截断,不为空- 抛出:
DateTimeException- 如果无法截断UnsupportedTemporalTypeException- 如果不支持该单元
-
plus
返回添加了指定数量的此日期时间的副本。这将返回一个
LocalDateTime,基于这个,添加了指定的数量。数量通常是Period或Duration但可以是实现TemporalAmount接口的任何其他类型。通过调用
TemporalAmount.addTo(Temporal)将计算委托给金额对象。金额实现可以自由地以任何它希望的方式实现加法,但是它通常会回调plus(long, TemporalUnit)。查阅amount实现的文档,判断是否可以添加成功。此实例是不可变的,不受此方法调用的影响。
- 指定者:
plus在接口ChronoLocalDateTime<LocalDate>中- 指定者:
plus在接口Temporal中- 参数:
amountToAdd- 添加的数量,不为空- 返回:
-
a
LocalDateTime基于此日期时间并添加,不为空 - 抛出:
DateTimeException- 如果无法添加ArithmeticException- 如果发生数字溢出
-
plus
返回添加了指定数量的此日期时间的副本。这将返回一个
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
返回此LocalDateTime的副本,并添加了指定的年数。此方法分三步将指定金额添加到年字段:
- 将输入年份添加到年份字段
- 检查结果日期是否无效
- 如有必要,将日期调整为最后一个有效日期
例如,2008-02-29(闰年)加上一年将导致无效日期 2009-02-29(标准年)。不是返回无效结果,而是选择该月的最后一个有效日期 2009-02-28。
此实例是不可变的,不受此方法调用的影响。
- 参数:
years- 添加的年份,可能为负- 返回:
LocalDateTime基于此日期时间加上年份,不为空- 抛出:
DateTimeException- 如果结果超出支持的日期范围
-
plusMonths
返回此LocalDateTime的副本,其中添加了指定的月数。此方法分三步将指定金额添加到月份字段:
- 将输入月份添加到月份字段
- 检查结果日期是否无效
- 如有必要,将日期调整为最后一个有效日期
例如,2007-03-31 加上一个月将导致无效日期 2007-04-31。不是返回无效结果,而是选择该月的最后一个有效日期 2007-04-30。
此实例是不可变的,不受此方法调用的影响。
- 参数:
months- 添加的月份,可能为负- 返回:
LocalDateTime基于此日期时间加上月份,不为空- 抛出:
DateTimeException- 如果结果超出支持的日期范围
-
plusWeeks
返回此LocalDateTime的副本,并添加了指定的周数。此方法将以周为单位的指定数量添加到天数字段,并根据需要递增月份和年份字段,以确保结果保持有效。仅当超过最大/最小年份时,结果才无效。
例如,2008-12-31 加上一周将得到 2009-01-07。
此实例是不可变的,不受此方法调用的影响。
- 参数:
weeks- 添加的周数,可能为负数- 返回:
LocalDateTime基于此日期时间并添加周数,不为空- 抛出:
DateTimeException- 如果结果超出支持的日期范围
-
plusDays
返回此LocalDateTime的副本,并添加了指定的天数。此方法将指定的金额添加到天数字段,并根据需要递增月份和年份字段,以确保结果保持有效。仅当超过最大/最小年份时,结果才无效。
例如,2008-12-31 加上一天将得到 2009-01-01。
此实例是不可变的,不受此方法调用的影响。
- 参数:
days- 添加的天数,可能是负数- 返回:
LocalDateTime基于此日期时间加上天数,不为空- 抛出:
DateTimeException- 如果结果超出支持的日期范围
-
plusHours
返回此LocalDateTime的副本,并添加了指定的小时数。此实例是不可变的,不受此方法调用的影响。
- 参数:
hours- 添加的小时数,可能为负数- 返回:
LocalDateTime基于此日期时间并添加了小时数,不为空- 抛出:
DateTimeException- 如果结果超出支持的日期范围
-
plusMinutes
返回此LocalDateTime的副本,并添加了指定的分钟数。此实例是不可变的,不受此方法调用的影响。
- 参数:
minutes- 添加的分钟数,可能为负数- 返回:
LocalDateTime基于此日期时间并添加分钟,不为空- 抛出:
DateTimeException- 如果结果超出支持的日期范围
-
plusSeconds
返回此LocalDateTime的副本,并添加了指定的秒数。此实例是不可变的,不受此方法调用的影响。
- 参数:
seconds- 添加的秒数,可能为负- 返回:
LocalDateTime基于此日期时间并添加了秒数,不为空- 抛出:
DateTimeException- 如果结果超出支持的日期范围
-
plusNanos
返回此LocalDateTime的副本,并添加了指定的纳秒数。此实例是不可变的,不受此方法调用的影响。
- 参数:
nanos- 要添加的纳米,可能为负- 返回:
LocalDateTime基于此日期时间并添加了纳秒,不为空- 抛出:
DateTimeException- 如果结果超出支持的日期范围
-
minus
返回此日期时间的副本,并减去指定的数量。这将返回一个
LocalDateTime,基于这个,减去指定的数量。数量通常是Period或Duration但可以是实现TemporalAmount接口的任何其他类型。通过调用
TemporalAmount.subtractFrom(Temporal)将计算委托给金额对象。金额实现可以自由地以任何它希望的方式实现减法,但是它通常会回调minus(long, TemporalUnit)。查阅 amount 实现的文档以确定是否可以成功减去。此实例是不可变的,不受此方法调用的影响。
- 指定者:
minus在接口ChronoLocalDateTime<LocalDate>中- 指定者:
minus在接口Temporal中- 参数:
amountToSubtract- 要减去的金额,不为空- 返回:
-
a
LocalDateTime基于这个日期时间减去,不为空 - 抛出:
DateTimeException- 如果无法进行减法ArithmeticException- 如果发生数字溢出
-
minus
返回此日期时间的副本,并减去指定的数量。这将返回一个
LocalDateTime,基于这个,减去单位数量。如果无法减去金额,因为不支持该单位或出于其他原因,则会抛出异常。此方法等同于
plus(long, TemporalUnit)取反金额。有关加法和减法如何工作的完整描述,请参阅该方法。此实例是不可变的,不受此方法调用的影响。
- 指定者:
minus在接口ChronoLocalDateTime<LocalDate>中- 指定者:
minus在接口Temporal中- 参数:
amountToSubtract- 要从结果中减去的单位数量,可能为负数unit- 要减去的金额的单位,不为空- 返回:
-
a
LocalDateTime基于此日期时间减去指定的金额,不为空 - 抛出:
DateTimeException- 如果无法进行减法UnsupportedTemporalTypeException- 如果不支持该单元ArithmeticException- 如果发生数字溢出
-
minusYears
返回此LocalDateTime的副本,并减去指定的年数。此方法分三步从年字段中减去指定的金额:
- 从年份字段中减去输入的年份
- 检查结果日期是否无效
- 如有必要,将日期调整为最后一个有效日期
例如,2008-02-29(闰年)减去一年将导致无效日期 2007-02-29(标准年)。不是返回无效结果,而是选择该月的最后一个有效日期 2007-02-28。
此实例是不可变的,不受此方法调用的影响。
- 参数:
years- 要减去的年份,可能为负数- 返回:
LocalDateTime基于此日期时间减去年份,不为空- 抛出:
DateTimeException- 如果结果超出支持的日期范围
-
minusMonths
返回此LocalDateTime的副本,并减去指定的月数。此方法分三步从月份字段中减去指定的金额:
- 从月份字段中减去输入的月份
- 检查结果日期是否无效
- 如有必要,将日期调整为最后一个有效日期
例如,2007-03-31 减去一个月将导致无效日期 2007-02-31。不是返回无效结果,而是选择该月的最后一个有效日期 2007-02-28。
此实例是不可变的,不受此方法调用的影响。
- 参数:
months- 要减去的月份,可能为负数- 返回:
LocalDateTime基于此日期时间减去月份,不为空- 抛出:
DateTimeException- 如果结果超出支持的日期范围
-
minusWeeks
返回此LocalDateTime的副本,并减去指定的周数。此方法从天字段中减去指定的周数,并根据需要递减月份和年份字段以确保结果保持有效。仅当超过最大/最小年份时,结果才无效。
例如,2009-01-07 减去一周将得到 2008-12-31。
此实例是不可变的,不受此方法调用的影响。
- 参数:
weeks- 要减去的周数,可能为负数- 返回:
LocalDateTime基于此日期时间减去周数,不为空- 抛出:
DateTimeException- 如果结果超出支持的日期范围
-
minusDays
返回此LocalDateTime的副本,并减去指定的天数。此方法从天字段中减去指定的金额,并根据需要递减月份和年份字段,以确保结果保持有效。仅当超过最大/最小年份时,结果才无效。
例如,2009-01-01 减去一天将得到 2008-12-31。
此实例是不可变的,不受此方法调用的影响。
- 参数:
days- 要减去的天数,可能为负数- 返回:
LocalDateTime基于此日期时间减去天数,不为空- 抛出:
DateTimeException- 如果结果超出支持的日期范围
-
minusHours
返回此LocalDateTime的副本,并减去指定的小时数。此实例是不可变的,不受此方法调用的影响。
- 参数:
hours- 要减去的小时数,可能为负数- 返回:
LocalDateTime基于此日期时间减去小时数,不为空- 抛出:
DateTimeException- 如果结果超出支持的日期范围
-
minusMinutes
返回此LocalDateTime的副本,并减去指定的分钟数。此实例是不可变的,不受此方法调用的影响。
- 参数:
minutes- 要减去的分钟数,可能为负数- 返回:
LocalDateTime基于此日期时间减去分钟数,不为空- 抛出:
DateTimeException- 如果结果超出支持的日期范围
-
minusSeconds
返回此LocalDateTime的副本,并减去指定的秒数。此实例是不可变的,不受此方法调用的影响。
- 参数:
seconds- 减去的秒数,可能为负数- 返回:
LocalDateTime基于此日期时间减去秒数,不为空- 抛出:
DateTimeException- 如果结果超出支持的日期范围
-
minusNanos
返回此LocalDateTime的副本,并减去指定的纳秒数。此实例是不可变的,不受此方法调用的影响。
- 参数:
nanos- 要减去的纳米,可能是负数- 返回:
LocalDateTime基于此日期时间减去纳秒,不为空- 抛出:
DateTimeException- 如果结果超出支持的日期范围
-
query
使用指定的查询查询此日期时间。这使用指定的查询策略对象查询此日期时间。
TemporalQuery对象定义了用于获取结果的逻辑。阅读查询文档以了解此方法的结果。此方法的结果是通过对指定查询调用
TemporalQuery.queryFrom(TemporalAccessor)方法并将this作为参数传递来获得的。- 指定者:
query在接口ChronoLocalDateTime<LocalDate>中- 指定者:
query在接口TemporalAccessor中- 类型参数:
R- 结果的类型- 参数:
query- 要调用的查询,不为空- 返回:
- 查询结果,可能返回null(由查询定义)
- 抛出:
DateTimeException- 如果无法查询(由查询定义)ArithmeticException- 如果发生数字溢出(由查询定义)
-
adjustInto
调整指定的时态对象,使其具有与该对象相同的日期和时间。这将返回一个与输入具有相同可观察类型的时间对象,日期和时间更改为与此相同。
调整相当于使用了两次
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
根据指定的单位计算到另一个日期时间的时间量。这根据单个
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的计算在此方法中实现。单位NANOS、MICROS、MILLIS、SECONDS、MINUTES、HOURS和HALF_DAYS、DAYS、WEEKS、MONTHS、支持YEARS、DECADES、CENTURIES、MILLENNIA和ERAS。其他ChronoUnit值将引发异常。如果单位不是
ChronoUnit,则通过调用TemporalUnit.between(Temporal, Temporal)将this作为第一个参数并将转换后的输入时间作为第二个参数来获得此方法的结果。此实例是不可变的,不受此方法调用的影响。
- 指定者:
until在接口Temporal中- 参数:
endExclusive- 结束日期,独占,转换为LocalDateTime,不为空unit- 衡量数量的单位,不为空- 返回:
- 此日期时间和结束日期时间之间的时间量
- 抛出:
DateTimeException- 如果无法计算数量,或者结束时间无法转换为LocalDateTimeUnsupportedTemporalTypeException- 如果不支持该单元ArithmeticException- 如果发生数字溢出
-
format
使用指定的格式化程序格式化此日期时间。此日期时间将传递给格式化程序以生成字符串。
- 指定者:
format在接口ChronoLocalDateTime<LocalDate>中- 参数:
formatter- 要使用的格式化程序,不为空- 返回:
- 格式化的日期时间字符串,不为空
- 抛出:
DateTimeException- 如果在打印过程中发生错误
-
atOffset
将此日期时间与偏移量组合以创建OffsetDateTime。这将返回一个
OffsetDateTime从该日期时间在指定的偏移量处形成。日期时间和偏移量的所有可能组合均有效。- 参数:
offset- 要结合的偏移量,不为空- 返回:
- 从此日期时间和指定的偏移量形成的偏移量日期时间,不为空
-
atZone
将此日期时间与时区组合以创建ZonedDateTime。这将返回在指定时区从该日期时间形成的
ZonedDateTime。结果将尽可能匹配此日期时间。时区规则,例如夏令时,意味着并非每个本地日期时间都对指定区域有效,因此可以调整本地日期时间。本地日期时间被解析为时间线上的单个瞬间。这是通过为由区域 ID 的
rules定义的本地日期时间找到与 UTC/格林威治的有效偏移量来实现的。在大多数情况下,本地日期时间只有一个有效偏移量。在重叠的情况下,时钟向后设置,有两个有效的偏移量。此方法使用通常对应于“夏季”的较早偏移量。
在间隙的情况下,时钟向前跳跃,没有有效的偏移量。相反,本地日期时间被调整为较晚的间隔长度。对于典型的一小时夏令时更改,本地日期时间将在一小时后移动到通常对应于“夏季”的偏移量中。
要在重叠期间获得后来的偏移量,请对此方法的结果调用
ZonedDateTime.withLaterOffsetAtOverlap()。要在存在间隙或重叠时抛出异常,请使用ZonedDateTime.ofStrict(LocalDateTime, ZoneOffset, ZoneId)。- 指定者:
atZone在接口ChronoLocalDateTime<LocalDate>中- 参数:
zone- 要使用的时区,不为空- 返回:
- 从此日期时间形成的分区日期时间,不为空
-
compareTo
将此日期时间与另一个日期时间进行比较。比较主要基于日期时间,从最早到最晚。正如
Comparable所定义的那样,它“与等于一致”。如果所有被比较的日期时间都是
LocalDateTime的实例,那么比较将完全基于日期时间。如果比较的某些日期处于不同的年表中,那么也会考虑年表,请参阅ChronoLocalDateTime.compareTo(java.time.chrono.ChronoLocalDateTime<?>)。- 指定者:
compareTo在接口ChronoLocalDateTime<LocalDate>中- 指定者:
compareTo在接口Comparable<ChronoLocalDateTime<?>>中- 参数:
other- 要比较的另一个日期时间,不为空- 返回:
- 比较值,小于则为负,大于则为正
-
isAfter
检查此日期时间是否在指定的日期时间之后。这将检查此日期时间是否代表本地时间线上另一个日期时间之后的一个点。
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
检查此日期时间是否早于指定的日期时间。这将检查此日期时间是否代表本地时间线上另一个日期时间之前的一个点。
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
检查此日期时间是否等于指定的日期时间。这将检查此日期时间是否表示本地时间线上与其他日期时间相同的点。
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
检查此日期时间是否等于另一个日期时间。将此
LocalDateTime与另一个进行比较,确保日期时间相同。只比较LocalDateTime类型的对象,其他类型返回 false。- 指定者:
equals在接口ChronoLocalDateTime<LocalDate>中- 重写:
equals在类Object中- 参数:
obj- 要检查的对象,null 返回 false- 返回:
- 如果这等于另一个日期时间,则为真
- 参见:
-
hashCode
public int hashCode()此日期时间的哈希码。- 指定者:
hashCode在接口ChronoLocalDateTime<LocalDate>中- 重写:
hashCode在类Object中- 返回:
- 合适的哈希码
- 参见:
-
toString
将此日期时间输出为String,例如2007-12-03T10:15:30。输出将是以下 ISO-8601 格式之一:
uuuu-MM-dd'T'HH:mmuuuu-MM-dd'T'HH:mm:ssuuuu-MM-dd'T'HH:mm:ss.SSSuuuu-MM-dd'T'HH:mm:ss.SSSSSSuuuu-MM-dd'T'HH:mm:ss.SSSSSSSSS
- 指定者:
toString在接口ChronoLocalDateTime<LocalDate>中- 重写:
toString在类Object中- 返回:
- 此日期时间的字符串表示形式,不为空
-