java Long类型精度丢失

解决JSON序列化时Long类型精度丢失问题
博客讨论了在数据库使用雪花算法生成Long类型ID时,前后端传递过程中出现精度丢失的问题。通过在字段上添加@JsonFormat注解,将Long类型转换为字符串,成功解决了单个字段的精度问题。对于List精度丢失的情况,作者提供了可能的解决方案,但未进行实际测试。

场景:
数据库id采用的是雪花算法,Long类型,在前后端传递过程,经度丢失。
解决办法:
对于单个的字段添加注解:
@JsonFormat(shape = JsonFormat.Shape.STRING)
private Long id;
解决
如图在这里插入图片描述
过程中同事遇到List精度丢失,但我本地没有再现。可以尝试
在这里插入图片描述
只是推荐方法没有测试List精度丢失问题

Java 中,使用 `@JsonFormat` 注解可以有效防止 `long` 类型数据在序列化为 JSON 时出现精度丢失问题。通过将 `long` 类型的字段格式化为字符串形式,可以规避 JSON 和 JavaScript 在处理大整数时的精度限制。具体实现方式如下: ### 使用 `@JsonFormat` 注解 `@JsonFormat` 注解允许开发者指定字段的序列化格式。通过设置 `shape = Shape.STRING`,可以将 `long` 类型字段以字符串形式输出,从而避免精度丢失问题。例如: ```java import com.fasterxml.jackson.annotation.JsonFormat; import com.fasterxml.jackson.databind.annotation.JsonDeserialize; import com.fasterxml.jackson.databind.annotation.JsonSerialize; @JsonFormat(shape = JsonFormat.Shape.STRING) private Long id; ``` 这样,当字段 `id` 被序列化为 JSON 时,其值将被转换为字符串,确保在前端(如 JavaScript)中能够正确处理大整数[^2]。 ### 与 `@JsonSerialize` 的对比 除了 `@JsonFormat` 外,还可以使用 `@JsonSerialize` 注解来实现类似的功能。例如: ```java import com.fasterxml.jackson.databind.annotation.JsonSerialize; import com.fasterxml.jackson.databind.ser.std.ToStringSerializer; @JsonSerialize(using = ToStringSerializer.class) private Long id; ``` `@JsonSerialize` 提供了更细粒度的控制,允许指定特定的序列化器(如 `ToStringSerializer`)。与 `@JsonFormat` 相比,`@JsonSerialize` 更适用于需要自定义序列化逻辑的场景[^4]。 ### 全局配置替代方案 虽然 `@JsonFormat` 和 `@JsonSerialize` 提供了字段级别的解决方案,但在实际开发中,如果需要对所有 `long` 类型字段进行统一处理,建议采用全局配置方式。例如,在 Spring 应用中,可以通过自定义 `ObjectMapper` 来实现全局的 `long` 类型序列化配置: ```java import com.fasterxml.jackson.databind.ObjectMapper; import com.fasterxml.jackson.databind.ser.std.ToStringSerializer; import com.fasterxml.jackson.databind.module.SimpleModule; import org.springframework.context.annotation.Configuration; import org.springframework.http.converter.HttpMessageConverter; import org.springframework.http.converter.json.MappingJackson2HttpMessageConverter; import org.springframework.web.servlet.config.annotation.WebMvcConfigurer; import java.util.List; @Configuration public class WebConfig implements WebMvcConfigurer { @Override public void configureMessageConverters(List<HttpMessageConverter<?>> converters) { ObjectMapper objectMapper = new ObjectMapper(); SimpleModule module = new SimpleModule(); module.addSerializer(Long.class, ToStringSerializer.instance); module.addSerializer(Long.TYPE, ToStringSerializer.instance); objectMapper.registerModule(module); MappingJackson2HttpMessageConverter converter = new MappingJackson2HttpMessageConverter(objectMapper); converters.add(converter); } } ``` 通过这种方式,可以避免在每个字段上手动添加注解,提高代码的可维护性[^3]。 ### 总结 - `@JsonFormat(shape = Shape.STRING)` 可以将 `long` 类型字段以字符串形式输出,防止精度丢失。 - `@JsonSerialize(using = ToStringSerializer.class)` 提供了更灵活的序列化控制。 - 全局配置 `ObjectMapper` 可以统一处理所有 `long` 类型字段的序列化行为。 ###
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

心系代码

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值