springboot 获取当前日期_java时间API,SpringBoot中应用LocalDateTime(日期转换)

本文介绍了Java 8引入的LocalDate、LocalTime、LocalDateTime等新时间API,指出旧的SimpleDateFormat线程不安全的问题,并展示了如何在SpringBoot中使用这些新API进行日期转换,包括时间戳与日期格式化的转换。
摘要由CSDN通过智能技术生成

参考资料:好好学Java  https://mp.weixin.qq.com/s/Dd_7yUh3lq3TqE2cjsYXvw

JDK8新特性里提供了3个时间类:LocalDate、LocalTime、LocalDateTime

在项目开发中,已经需要对Date类型进行格式,否则可读性很差,格式化Date类型要使用SimpleDateFormat,但SimpleDateFormat是现成不安全的。

1. 为什么需要LocalDate、LocalTime、LocalDateTime

1.1 Date如果不格式化,打印出的日期可读性差

Tue Sep 10 09:34:04 CST 2019

1.2 使用SimpleDateFormat对时间进行格式化,但SimpleDateFormat是线程不安全的。SimpleDateFormat的format方法最终调用代码:

privateStringBuffer 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

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

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

if (count == 255) {

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

count |= compiledPattern[i++];

}

switch(tag) {

caseTAG_QUOTE_ASCII_CHAR:

toAppendTo.append((char) count);

break;

caseTAG_QUOTE_CHARS:

toAppendTo.append(compiledPattern, i, count);

i +=count;

break;

default:

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

break;

}

}

returntoAppendTo;

}

calendar是共享变量,并且这个共享变量没有做线程安全控制。当多个线程同时使用相同的SimpleDateFormat对象【如用static修饰的SimpleDateFormat】调用format方法时,多个线程会同时调用calendar.setTime方法,可能一个线程刚设置好time值 另外的一个线程马上把设置的time值给修改了导致返回的格式化时间可能是错误的。

在多并发情况下使用SimpleDateFormat需格外注意 SimpleDateFormat除了format是线程不安全以外,parse方法也是线程不安全的。parse方法实际调用alb.establish(calendar).getTime()方法来解析,alb.establish(calendar)方法里主要完成了

a、重置日期对象cal的属性值

b、使用calb中中属性设置cal

c、返回设置好的cal对象

但是这三步不是原子操作。

多线程并发如何保证线程安全 - 避免线程之间共享一个SimpleDateFormat对象,每个线程使用时都创建一次SimpleDateFormat对象 => 创建和销毁对象的开销大 - 对使用format和parse方法的地方进行加锁 => 线程阻塞性能差 - 使用ThreadLocal保证每个线程最多只创建一次SimpleDateFormat对

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值