Java - Fastjson 序列化/反序列化之『科学计数法』解决方案

问题描述

这次是在 Kafka 消费者 @Payload 发现消息被反序列化的时候,浮点数类型,准确来说这里指的是 Double 类型,比如:123456792(1.23456792E8)

原因分析

经过排查发现,想直接解决 Kafka @Payload 根本问题还是比较难,如果有大佬发现可以评论哈~

所以只能在后面做数据加工处理,但也没那么简单,因为直接对 Double 可用的解决科学计数法没找到,只有 BIgDecimal 的。

解决方案

java 复制代码
/**
 * 处理 JSON 特性
 * - 科学计数法
 * @param object
 * @return
 */
public static Object evalJson(Object object) {
	String jsonString = JSON.toJSONString(object);
	JSONObject jsonObject = JSON.parseObject(jsonString);

    # 为什么要多做一次上面的序列化、反序列化呢? 因为先把 Double 类型转化为 BigDecimal 为下面可以利用 BigDecimal 特性做准备
	jsonString = JSON.toJSONString(jsonObject, SerializerFeature.WriteBigDecimalAsPlain);

	return JSON.parseObject(jsonString);
}

Ps:网上很多都是在啥实体类上加注解,那个当然可以理解,问题是 JSON 有时候面向更多的是临时动态对象,哪来的固定字段加呀~ 所以那些方法我就不重复轮子了,主要提供下针对全局解决这个问题的思路

相关推荐
武子康5 分钟前
Hadoop-11-MapReduce JOIN 操作的Java实现 Driver Mapper Reducer具体实现逻辑 模拟SQL进行联表操作
java·大数据·hadoop·分布式·sql·mapreduce
希昂的学习日记9 分钟前
NIO基础
java·nio
JIAWAP12 分钟前
Linux环境安装Maven
java·linux·centos·maven
年轻的高血压患者14 分钟前
基于Java的水果商品销售网站
java·sql·mysql·servlet·架构·eclipse·idea
*Soo_Young*19 分钟前
【Spring AOP 源码解析前篇】什么是 AOP | 通知类型 | 切点表达式| AOP 如何使用
java·spring·aop
剑海风云1 小时前
GraalVM简介及使用
java·jvm·graalvm·编译器·本地镜像
ZHOU_VIP1 小时前
GuLi商城-商品服务-API-品牌管理-OSS整合测试(续)
java
小白要code1 小时前
线程池理解及7个参数
java
伏颜.2 小时前
Spring懒加载Bean机制
java·spring
细心的莽夫2 小时前
集合复习(java)
java·开发语言·笔记·学习·java-ee