日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

localdatetime 默认时间_为什么建议使用你 LocalDateTime ,而不是 Date?

發布時間:2025/4/5 编程问答 42 豆豆
生活随笔 收集整理的這篇文章主要介紹了 localdatetime 默认时间_为什么建议使用你 LocalDateTime ,而不是 Date? 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

為什么需要LocalDate、LocalTime、LocalDateTime

Come On 一起使用java8全新的日期和時間API

小結在項目開發過程中經常遇到時間處理,但是你真的用對了嗎,理解阿里巴巴開發手冊中禁用static修飾SimpleDateFormat嗎

通過閱讀本篇文章你將了解到:為什么需要LocalDate、LocalTime、LocalDateTime【java8新提供的類】

java8新的時間API的使用方式,包括創建、格式化、解析、計算、修改

為什么需要LocalDate、LocalTime、LocalDateTimeDate如果不格式化,打印出的日期可讀性差

Tue Sep 10 09:34:04 CST 2019

使用SimpleDateFormat對時間進行格式化,但SimpleDateFormat是線程不安全的SimpleDateFormat的format方法最終調用代碼:

private StringBuffer format(Date date, StringBuffer toAppendTo,

FieldDelegate delegate) {

// Convert input date to time field list

calendar.setTime(date);boolean useDateFormatSymbols = useDateFormatSymbols();

for (int i = 0; i < compiledPattern.length; ) {

int tag = compiledPattern[i] >>> 8;

int count = compiledPattern[i++] & 0xff;

if (count == 255) {

count = compiledPattern[i++] << 16;

count |= compiledPattern[i++];

}

switch (tag) {

case TAG_QUOTE_ASCII_CHAR:

toAppendTo.append((char)count);

break;

case TAG_QUOTE_CHARS:

toAppendTo.append(compiledPattern, i, count);

i += count;

break;

default:

subFormat(tag, count, delegate, toAppendTo, useDateFormatSymbols);

break;

}

}

return toAppendTo;

}

calendar是共享變量,并且這個共享變量沒有做線程安全控制。當多個線程同時使用相同的SimpleDateFormat對象【如用static修飾的SimpleDateFormat】調用format方法時,多個線程會同時調用calendar.setTime方法,可能一個線程剛設置好time值另外的一個線程馬上把設置的time值給修改了導致返回的格式化時間可能是錯誤的。在多并發情況下使用SimpleDateFormat需格外注意SimpleDateFormat除了format是線程不安全以外,parse方法也是線程不安全的。parse方法實際調用alb.establish(calendar).getTime()方法來解析,alb.establish(calendar)方法里主要完成了

1、 重置日期對象cal的屬性值

2 使用calb中中屬性設置cal

3. 返回設置好的cal對象

但是這三步不是原子操作

多線程并發如何保證線程安全 - 避免線程之間共享一個SimpleDateFormat對象,每個線程使用時都創建一次SimpleDateFormat對象 => 創建和銷毀對象的開銷大 - 對使用format和parse方法的地方進行加鎖 => 線程阻塞性能差 - 使用ThreadLocal保證每個線程最多只創建一次SimpleDateFormat對象 => 較好的方法Date對時間處理比較麻煩,比如想獲取某年、某月、某星期,以及n天以后的時間,如果用Date來處理的話真是太難了,你可能會說Date類不是有getYear、getMonth這些方法嗎,獲取年月日很Easy,但都被棄用了啊

Come On 一起使用java8全新的日期和時間API

LocalDate

只會獲取年月日創建LocalDate

//獲取當前年月日

LocalDate localDate = LocalDate.now();

//構造指定的年月日

LocalDate localDate1 = LocalDate.of(2019, 9, 10);

獲取年、月、日、星期幾

int year = localDate.getYear();

int year1 = localDate.get(ChronoField.YEAR);

Month month = localDate.getMonth();

int month1 = localDate.get(ChronoField.MONTH_OF_YEAR);

int day = localDate.getDayOfMonth();

int day1 = localDate.get(ChronoField.DAY_OF_MONTH);

DayOfWeek dayOfWeek = localDate.getDayOfWeek();

int dayOfWeek1 = localDate.get(ChronoField.DAY_OF_WEEK);

LocalTime

只會獲取幾點幾分幾秒創建LocalTime

LocalTime localTime = LocalTime.of(13, 51, 10);

LocalTime localTime1 = LocalTime.now();

獲取時分秒

//獲取小時

int hour = localTime.getHour();

int hour1 = localTime.get(ChronoField.HOUR_OF_DAY);

//獲取分

int minute = localTime.getMinute();

int minute1 = localTime.get(ChronoField.MINUTE_OF_HOUR);

//獲取秒

int second = localTime.getSecond();

int second1 = localTime.get(ChronoField.SECOND_OF_MINUTE);

LocalDateTime

獲取年月日時分秒,等于LocalDate+LocalTime創建LocalDateTime

LocalDateTime localDateTime = LocalDateTime.now();

LocalDateTime localDateTime1 = LocalDateTime.of(2019, Month.SEPTEMBER, 10, 14, 46, 56);

LocalDateTime localDateTime2 = LocalDateTime.of(localDate, localTime);

LocalDateTime localDateTime3 = localDate.atTime(localTime);

LocalDateTime localDateTime4 = localTime.atDate(localDate);

獲取LocalDate

LocalDate localDate2 = localDateTime.toLocalDate();

獲取LocalTime

LocalTime localTime2 = localDateTime.toLocalTime();

Instant

獲取秒數創建Instant對象

Instant instant = Instant.now();

獲取秒數

long currentSecond = instant.getEpochSecond();

獲取毫秒數

long currentMilli = instant.toEpochMilli();

個人覺得如果只是為了獲取秒數或者毫秒數,使用System.currentTimeMillis()來得更為方便

修改LocalDate、LocalTime、LocalDateTime、Instant

LocalDate、LocalTime、LocalDateTime、Instant為不可變對象,修改這些對象對象會返回一個副本增加、減少年數、月數、天數等 以

LocalDateTime

為例

LocalDateTime localDateTime = LocalDateTime.of(2019, Month.SEPTEMBER, 10,

14, 46, 56);

//增加一年

localDateTime = localDateTime.plusYears(1);

localDateTime = localDateTime.plus(1, ChronoUnit.YEARS);

//減少一個月

localDateTime = localDateTime.minusMonths(1);

localDateTime = localDateTime.minus(1, ChronoUnit.MONTHS);

通過

with

修改某些值

//修改年為2019

localDateTime = localDateTime.withYear(2020);

//修改為2022

localDateTime = localDateTime.with(ChronoField.YEAR, 2022);

還可以修改月、日

時間計算

比如有些時候想知道這個月的最后一天是幾號、下個周末是幾號,通過提供的時間和日期API可以很快得到答案

LocalDate localDate = LocalDate.now();

LocalDate localDate1 = localDate.with(firstDayOfYear());

比如通過firstDayOfYear()返回了當前日期的第一天日期,還有很多方法這里不在舉例說明

格式化時間

LocalDate localDate = LocalDate.of(2019, 9, 10);

String s1 = localDate.format(DateTimeFormatter.BASIC_ISO_DATE);

String s2 = localDate.format(DateTimeFormatter.ISO_LOCAL_DATE);

//自定義格式化

DateTimeFormatter dateTimeFormatter = DateTimeFormatter.ofPattern("dd/MM/yyyy");

String s3 = localDate.format(dateTimeFormatter);

DateTimeFormatter默認提供了多種格式化方式,如果默認提供的不能滿足要求,可以通過DateTimeFormatter的ofPattern方法創建自定義格式化方式

解析時間

LocalDate localDate1 = LocalDate.parse("20190910", DateTimeFormatter.BASIC_ISO_DATE);

LocalDate localDate2 = LocalDate.parse("2019-09-10", DateTimeFormatter.ISO_LOCAL_DATE);

和SimpleDateFormat相比,DateTimeFormatter是線程安全的

小結

LocalDateTime`:`Date`有的我都有,`Date`沒有的我也有,日期選擇請`Pick Me

====================== Update On 2019/09/18 =================

SpringBoot中應用LocalDateTime將LocalDateTime字段以時間戳的方式返回給前端 添加日期轉化類

public class LocalDateTimeConverter extends JsonSerializer {

@Override

public void serialize(LocalDateTime value, JsonGenerator gen, SerializerProvider serializers) throws IOException {

gen.writeNumber(value.toInstant(ZoneOffset.of("+8")).toEpochMilli());

}

}

并在

LocalDateTime

字段上添加

@JsonSerialize(using = LocalDateTimeConverter.class)

注解,如下:

@JsonSerialize(using = LocalDateTimeConverter.class)

protected LocalDateTime gmtModified;

將LocalDateTime字段以指定格式化日期的方式返回給前端 在

LocalDateTime

字段上添加

@JsonFormat(shape=JsonFormat.Shape.STRING, pattern="yyyy-MM-dd HH:mm:ss")

注解即可,如下:

@JsonFormat(shape=JsonFormat.Shape.STRING, pattern="yyyy-MM-dd HH:mm:ss")

protected LocalDateTime gmtModified;

對前端傳入的日期進行格式化 在

LocalDateTime

字段上添加

@DateTimeFormat(pattern = "yyyy-MM-dd HH:mm:ss")

注解即可,如下:

@DateTimeFormat(pattern = "yyyy-MM-dd HH:mm:ss")

protected LocalDateTime gmtModified;

作者:何甜甜在嗎

:-D 搜索微信號(ID:芋道源碼),可以獲得各種 Java 源碼解析、原理講解、面試題、學習指南。

:-D 并且,回復【書籍】后,可以領取筆者推薦的各種 Java 從入門到架構的 100 本書籍。

:-D 并且,回復【技術群】后,可以加入專門討論 Java、后端、架構的技術群。

來吧,騷年~

總結

以上是生活随笔為你收集整理的localdatetime 默认时间_为什么建议使用你 LocalDateTime ,而不是 Date?的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。