一、前言
发现一个很有意思的问题,@ToString注解的一些细节,分享给大家
二、问题
因为调第三方接口,用了别人之前创建的对象。发现调用feign的时候总是报null,经过排查发现调用feign的时候会报numberformatexception异常,如下图。这就很奇怪,经过比对,字段没问题,怎么会异常呢。我就自己新创建了一个对象来测试,发现不报错,于是仔细排查了下。
三、分析
发现这个对像有 getDeviceType()方法,根据buyTime字段为deviceType赋值。经过打断点,发现feign接口调用的时候会走这个方法。经过一番了解发现,根据 Lombok 的默认规则,@ToString 会在生成的 toString() 方法中包含所有字段(包括通过 getter 获取的字段)。因此,在上述示例中,如果 deviceType 字段存在,并且有 getDeviceType() 方法,那么 Lombok 会自动调用 getDeviceType() 方法来获取值用于 toString()。
四、解决方案
因为该字段为null,方法名特殊Lombok会自动调用,才导致异常,所以该方法加个判null。或者加个@ToString(exclude = "buyTime")就ok.
好啦,这次分享就这里,对你有帮助的话,帮我点个赞哈!