bug随笔

本文探讨了如何在Java中使用@JsonFormat正确处理Date类型的序列化问题,强调了指定时区的重要性,并解释了getDeclaredField和getField在反射中的区别。此外,还讨论了@Async注解的使用限制,尤其是在异步方法的组织和Spring框架中的行为。
摘要由CSDN通过智能技术生成

对Date类型使用@JsonFormat注解

  • 当对java.util.Date日期类型使用@JsonFormat注解序列化返回给前端的时间格式时,必须指定时区

    原因:
    JASKSON在序列化时间时是按照国际标准时间GMT进行格式化的,而在国内默认时区使用的是CST时区,两者相差8小时,因为我们是东八区(北京时间),所以我们在格式化的时候要指定时区(timezone)。

    中国时间(Asia/Shanghai)=格林尼治时间(GMT)+8
    格林尼治时间(GMT)=世界协调时间(UTC)+0

  • 如果使用的时间类型是LocalDateTime或LocalTime,则可以直接使用注解,不必指定时区

    @JsonFormat(pattern = "yyyy-MM-dd HH:mm:ss")
    private Local Date Time createtime;
    @JsonFormat(pattern = "HH:mm:ss")
    private LocalTime createtime;
    
    @JsonFormat(pattern = "yyy-MM-dd HH:mm:ss", timezone="GMT+8")
    private Date createtime;
    
    

如果使用的是java.util.Date类型
Jackson和FastJson都是默认将日期类型转成了时间戳。
在这里插入图片描述
如果使用的是LocalDateTime类型
Jackson将日期类型转成了数组。
在这里插入图片描述

反射中getDeclaredField和getField区别

1、getDeclaredFiled仅能获取类本身的属性成员(包括私有、共有、保护
2、getField仅能获取类public属性成员

@Async失效情况

  1. 注解@Async的方法必须是public方法
  2. 注解@Async的返回值只能为void或者Future
  3. 注解@Async方法使用static修饰也会失效
  4. spring无法扫描到异步类,没加注解@Async 或 @EnableAsync注解
  5. 调用方与被调方不能在同一个类
    Spring 在扫描bean的时候会扫描方法上是否包含@Async注解,动态地生成一个子类(即proxy代理类),当这个有注解的方法被调用的时候,实际上是由代理类来调用的,代理类在调用时增加异步作用。
    如果这个有注解的方法是被同一个类中的其他方法调用的,那么该方法的调用并没有通过代理类,而是直接通过原来的那个 bean,所以就失效了。
    所以调用方与被调方不能在同一个类,主要是使用了动态代理,同一个类的时候直接调用,不是通过生成的动态代理类调用。
    一般将要异步执行的方法单独抽取成一个类。
  6. 类中需要使用@Autowired或@Resource等注解自动注入,不能自己手动new对象
  7. 在Async 方法上标注@Transactional是没用的,但在Async 方法调用的方法上标注@Transactional 是有效的
  8. 附说明
    直接使用 @Async 注解没指定线程池的话,即未设置TaskExecutor时
    默认使用Spring创建ThreadPoolTaskExecutor
    核心线程数:8
    最大线程数:Integer.MAX_VALUE ( 21亿多)
    队列使用LinkedBlockingQueue
    容量是:Integer.MAX_VALUE
    空闲线程保留时间:60s
    线程池拒绝策略:AbortPolicy
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值