Работа с датами в JVM
#
Васильев Андрей Михайлович, 2024
Версии презентации
Даты — это сложно
#
В повседневной жизни даты кажутся достаточно простыми, всегда можно договориться
о встрече в 19:30 в четверг на следующей неделе
- Указанная дата относительна текущего момента времени
- Хорошо, если место встречи географически близкое, в противном случае надо
учесть часовые пояса текущего места и места встречи
- За это время может произойти смена летнего / зимнего времени
- В это время может случиться добавление 1 секунды для согласования солнечного
времени
- За 2 недели может случиться, а может не случиться 29 февраля
- Если мы будем общаться по телефону и скажем, что встреча будет в “семь
тридцать”, то это будет 7:30 или 19:30?
- Разработчики Kotlin не готовы предоставить свои классы для описания даты
Дата и время в JVM
#
Почти с самого начала в рамках JVM поставлялись классы java.util.Date
,
java.util.Time
, которые не учитывали многие из поднятых вопросов
В рамках выпуска Java 8 был представлен пакет java.time
, включающий классы
LocalDateTime
, LocalDate
и другие
- Обеспечивают поточную безопасность, т.к. неизменяемые
- Предоставляют широкий список методов для манипулирования и датами
- Предоставлены Zoned-классы с поддержкой часовых поясов
Работа с классом LocalDateTime
#
Для создания объекта данного класса можно воспользоваться статическими методами
now()
— получает информацию о текущем моменте времени
of()
— создать дату из отдельных компонент, включая элементы даты и времени
parse()
— создать дату из строкового представления
Последний метод имеет второй необязательный аргумент, формат представления даты.
Если его не указать, то метод будет использовать формат даты в ISO, который
также определён в константе ISO_LOCAL_DATE_TIME
класса DateTimeFormatter
Если обрабатываемая строка не совпадает с переданным шаблоном, будет выброшено
исключение DateTimeParseException
Вычисление относительных моментов времени
#
При наличии объекта LocalDateTime можно создать новый объект, содержащий момент
времени относительно текущего с помощью методов
minusYears
, minusMonths
, minusDays
, minusHours
, minusMinutes
,
minusSeconds
plusYears
, plusMonths
, plusDays
, plusHours
, plusMinutes
,
plusSeconds
Созданный объект будет отличаться от оригинального на указанное значение
Для замены какого-то элемента даты можно воспользоаться with
-методами:
withYears
, withMonths
, withDays
, withHours
, withMinutes
, withSeconds
Сравнение дат
#
Объекты класса LocalDateTime можно сравнивать друг с другом в логических
выражениях, т.к. он реализует интерфейс Comparable
Также предоставляется ряд отдельных методов:
isAfter
— проверяет если данный момент следует за моментом в аргументе
isBefole
— проверяет если данный момент раньше момента в аргументе
isEqual
— проверка на равенство с моментом времени в аргументе
Преобразование к строке
#
Предоставляется несколько методов
- Стандартный метод
toString()
— возвращает строковый литерал в одном из
ISO-формате
- Метод
format()
, который принимает в качестве аргумента объект класса
DateTimeFormatter
Последний метод рекомендуется использовать в случае обмена данными с другими
приложениями, чтобы формат данных соблюдался