- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
在我的应用程序中,一个实体建模如下:
class Node{
private String parentNodeId;
private Node parentNode;
// other properties and their `getters` and setters
}
因为我正在使用 NoSql
DB 的非规范化形式。每个节点都有其父节点引用。这样,在数据库中我就有 540 条记录,大约是 4Mb 的 JSON 数据。从数据库获取这些记录不需要太多时间(70ms)。但将这些数据从 JSON
反序列化为 Java 对象需要近 1500 毫秒。合并所有请求来完成它需要 2000 毫秒。进行转换的代码如下
List<String> records = DB.get("some criteria");
List<Node> results = Lists.newArrayList();
for(String entity : records){
results.add(convertJSONToObject(entity, Node.class));
}
private <T> T convertJSONToObject(String record, Class<T> entityClass){
if(StringUtils.isBlank(json)){
return null;
}
ObjectReader reader = MAPPER.reader(objectClass);
return reader.readValue(json);
}
有没有更好的方法可以减少转换时间,或者这个速度对于那么多数据来说是可以接受的?
最佳答案
由于将对象模型完全保存在内存中以及这些模型的复杂性(可能有很多 POJO),文档解析器可能相当重。
首先,值得对反序列化过程进行分析,以确保它不会受到 IO 限制、花费大量时间进行反射或发生某种线程争用。其中可能存在一些您可以轻松修复或优化的问题。
其次,现代系统上的性能可以通过多线程获得很大的提高。也许可以考虑将您的 JSON 模型分解为多个部分并并行反序列化它们,或者看看 Jackson 是否可以选择为您执行此操作。
如果您要定期需要这些对象,并且您的数据有一定的生命周期,您可能需要考虑缓存这些对象并拥有一种在适当的时间使它们失效或更新的机制。您还应该考虑排除您不会使用的字段。
另一件需要注意的事情是您是否需要立即反序列化整个对象。我相信 Jackson 确实有能力提供随机访问,因此,当您等待 1500 毫秒进行反序列化时,您可以通过该方法提供临时访问并简单地反序列化所需的字段。或者,完全采用这种方法——为什么要反序列化你不需要的东西?
更进一步,如果您正在处理所有对象,您可能需要考虑使用流解析器。如果这是工作流程的一部分并且不排除在此过程中 fork 对象模型,那么这将更适合。
如果您不确定 jackson 的表现,可能值得分析替代方案,看看它们是否做得更好。在某些条件下,GSON已被证明比Jackson快很多,还有JSONP和JSON.simple。针对您的用例进行基准测试将使您更好地了解其中哪些最适合您。
关于java - 在 Jackson 中将 4Mb JSON 转换为 java 对象需要 1500 毫秒,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/33827693/
我找不到关于 jackson 的ObjectMapper与其他映射器(例如dozer/mapStruct/modelMapping/etc)之间的区别的任何解释。所有文章都比较了dozer/mapSt
我正在使用Jackson来反序列化Kotlin数据类。我正在使用jackson-kotlin-module,但 jackson 却给我以下错误: Can not construct instance
我正在尝试将包从“com.fasterxml.jackson”重新定位到我自己的包(即“mypackage.com.fasterxml.jackson”),然后在我拥有的另一个 JAR 中使用它。 我
对于JSON对象,Subject: { "permissions":["foo", "bar"], ... } ...我想反序列化为: class Subject { priv
我正在使用 @JsonTypeInfo 和 @JsonSubTypes 来映射基于给定属性的解析子类。这是我想要解析的示例 JSON 的一个人为示例。 { "animals": [ { "
我们正在使用 dropwizard 版本 0.6.3。当我们尝试升级 0.7.0 版本时,我们在服务启动时收到此错误。 线程“main”中的异常 java.lang.VerifyError: clas
我正在尝试实现自定义解串器。因为我只想向默认反序列化器添加功能,所以我尝试在我的自定义反序列化器中存储默认反序列化器:我想使用默认反序列化 json,然后添加其他信息。 我正在尝试使用 BeanDes
我有一个这样的类(class): public class Person { private String name; public String getName(){ return
我有以下 Kotlin 数据类: data class TestObject( val boolField: Boolean, val stringField: Str
使用 Jackson 库,在 Eclipse 4.9.0 版本中出现以下错误 缺少工件 com.fasterxml.jackson.core:jackson-databind:bundle:2.9.6
我试图在我的应用程序中从azure实现keyvault,在为DefaultAzureCredentialBuilder()实现azure-identity:1.5.4 lib后,它会抛出链接错误,如下
我试图在我的应用程序中从azure实现keyvault,在为DefaultAzureCredentialBuilder()实现azure-identity:1.5.4 lib后,它会抛出链接错误,如下
我知道我们可以使用 Jackson MixIn 来重命名属性或忽略属性(参见示例 here )。但是可以添加属性吗? 添加的属性可以是: 一个常数(如版本号) 计算值(例如,如果源类具有 getWid
我有一个在 Wildfly 10 上运行的应用程序,它需要更新版本的 jackson。简单地更新 maven 依赖是行不通的。 Wildflys 自己的版本似乎干扰了... 有人有提示吗? 最佳答案
我在 Tomcat 休息应用程序中运行 Jersey 2.5.1 & Jackson。对于我最初将 POJO 简单地转换为 JSON 的用例,基本设置效果很好。集合很好地转换为 json 数组,如下所
有没有办法告诉 jackson 在序列化过程中忽略那些用非 jackson 注释注释的字段? 例如: @SomeAnnotation private String foo; 我知道有 jackson
我遇到了 jackson 序列化问题, map 中存在空值。显然,这是 Wildfly 9 使用的 Jackson 版本中的一个已知错误 ( https://issues.jboss.org/brow
给定一个像这样的 JSON 映射类: public class Person { @JsonProperty String getName() { ... } @JsonPro
如何让 Jackson 的 XMLMapper 在反序列化时读取根 xml 元素的名称? 我正在将输入 XML 反序列化为通用 Java 类、LinkedHashMap,然后反序列化为 JSON。我想
我对抽象类和 JSON 序列化和反序列化的对象引用有问题。抽象的问题如下所示: 我有一个由节点和边组成的图。每条边连接两个节点。节点可以是红色和绿色的。因此,有一个抽象类Node和两个派生类 RedN
我是一名优秀的程序员,十分优秀!