java jid_Java对象中如何使用JID来进行高性能序列_Java程序_Java对象_课课家

2023-10-29 13:59

本文主要是介绍java jid_Java对象中如何使用JID来进行高性能序列_Java程序_Java对象_课课家,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

JID 是一个用来反序列化、更新和重新序列化 Map 对象,在 i5 2.53GHz 处理器的机器上,完成 10000 条目的操作仅需 4 毫秒。序列化和重新序列化的时间很大程度上依赖于表条目的大小和复杂度,增量式的序列化和反序列化用于达到高性能。

c8b8ee19af7b5655b20fc70d32c6bc9b.png

今天我试验了下使用 JID 进行 java 对象的序列化过程,现将这个过程与大家分享,至于在何种场景下使用大家自己发挥。

首先 JID 依赖于 JActor 和 SLF4J ,你下载的 JID 压缩包中就包含这二者的 jar 文件。

大家先不需要关心代码中牵扯的一些类是作何用途的,先把例子跑起来!

我们这里假设要对一个 User 对象进行序列化,User 对象如下:

/**

* 序列化对象

* @author Winter Lau

*/

public static class User extends appJid {

private StringJid getNameJid() throws Exception {

return (StringJid) _iGet(0);

}

private IntegerJid getAgeJid() throws Exception {

return (IntegerJid) _iGet(1);

}

public String getName() throws Exception {

return getNameJid().getValue();

}

public void setName(String name) throws Exception {

getNameJid().setValue(name);

}

public int getAge() throws Exception {

return getAgeJid().getValue();

}

public void setAge(int age) throws Exception {

getAgeJid().setValue(age);

}

}

然后每个要做序列化的对象都需要有个对应的工厂类,这里是 UserFactory:

public static class UserFactory extends AppJidFactory {

final public static UserFactory fac = new UserFactory();

public UserFactory() {

super("User", JidFactories.STRING_JID_TYPE, JidFactories.INTEGER_JID_TYPE);

}

protected User instantiateActor() throws Exception {

return new User();

}

}

其中特别注意 UserFactory 构造函数里的 "User" 这个参数,下面需要用到。

接下来就是测试程序:

public static void main(String[] args) throws Exception {

JAFactory factory = new JAFactory(){{(new JidFactories()).initialize(this);}};

factory.registerActorFactory(UserFactory.fac);

RootJid rootJid = (RootJid) factory.newActor(JidFactories.ROOT_JID_TYPE);

long ct = System.currentTimeMillis();

rootJid.setValue("User");

User user = (User)rootJid.getValue();

user.setName("Winter Lau");

user.setAge(98);

int slen = rootJid.getSerializedLength();

byte[] sdatas = new byte[slen];

rootJid.save(sdatas, 0);

rootJid.load(sdatas, 0, slen);

User user1 = (User)rootJid.getValue();

System.out.printf("%dms->%s:%d\\n", (System.currentTimeMillis()-ct), user1.getName(), user1.getAge());

}

程序讲解:

1. 首先需要构造 JAFactory ,这是使用 JID 必须的一步(第3行)

2. 然后注册我们需要进行序列化的类(第4行)

3. 构造 RootJid,这也是必须的一步(第6行)

4. rootJid.setValue("User") 这是设置要进行序列化的对象类型,这个 "User" 就是我们在 UserFactory 定义的字符串

5. 对 User 对象实例进行值设置

6. 使用 rootJid.save 方法进行序列化,就是把对象转称 byte 数组

7. 最后一步是演示从 byte 数据中加载对象并打印对象的属性

这便是一个完整的使用 JID 进行自定义对象的序列化和反序列化的过程。如果你是使用 Java 原生的一些数据类型,就不需要自行创建类对象。

这里需要很注意的是 UserFactory 中构造函数的参数顺序,第一个参数是类型名称,接下来的每个参数是对应每个属性的类型,这个必须严格对应 User 类中的 _iGet(xx) 中 xx 的值。

据说 JID 的序列化的性能是极高的,这方面我还没进行测试。需要注意的是这个序列化的结果和 Java 本身的序列化是不兼容的。

这篇关于java jid_Java对象中如何使用JID来进行高性能序列_Java程序_Java对象_课课家的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!


原文地址:https://blog.csdn.net/weixin_36301639/article/details/114105624
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.chinasem.cn/article/301120

相关文章

Spring Boot中的路径变量示例详解

《SpringBoot中的路径变量示例详解》SpringBoot中PathVariable通过@PathVariable注解实现URL参数与方法参数绑定,支持多参数接收、类型转换、可选参数、默认值及... 目录一. 基本用法与参数映射1.路径定义2.参数绑定&nhttp://www.chinasem.cnbs

C++中assign函数的使用

《C++中assign函数的使用》在C++标准模板库中,std::list等容器都提供了assign成员函数,它比操作符更灵活,支持多种初始化方式,下面就来介绍一下assign的用法,具有一定的参考价... 目录​1.assign的基本功能​​语法​2. 具体用法示例​​​(1) 填充n个相同值​​(2)

MySQL深分页进行性能优化的常见方法

《MySQL深分页进行性能优化的常见方法》在Web应用中,分页查询是数据库操作中的常见需求,然而,在面对大型数据集时,深分页(deeppagination)却成为了性能优化的一个挑战,在本文中,我们将... 目录引言:深分页,真的只是“翻页慢”那么简单吗?一、背景介绍二、深分页的性能问题三、业务场景分析四、

JAVA中安装多个JDK的方法

《JAVA中安装多个JDK的方法》文章介绍了在Windows系统上安装多个JDK版本的方法,包括下载、安装路径修改、环境变量配置(JAVA_HOME和Path),并说明如何通过调整JAVA_HOME在... 首先去oracle官网下载好两个版本不同的jdk(需要登录Oracle账号,没有可以免费注册)下载完

Spring StateMachine实现状态机使用示例详解

《SpringStateMachine实现状态机使用示例详解》本文介绍SpringStateMachine实现状态机的步骤,包括依赖导入、枚举定义、状态转移规则配置、上下文管理及服务调用示例,重点解... 目录什么是状态机使用示例什么是状态机状态机是计算机科学中的​​核心建模工具​​,用于描述对象在其生命

Spring Boot 结合 WxJava 实现文章上传微信公众号草稿箱与群发

《SpringBoot结合WxJava实现文章上传微信公众号草稿箱与群发》本文将详细介绍如何使用SpringBoot框架结合WxJava开发工具包,实现文章上传到微信公众号草稿箱以及群发功能,... 目录一、项目环境准备1.1 开发环境1.2 微信公众号准备二、Spring Boot 项目搭建2.1 创建

Java中Integer128陷阱

《Java中Integer128陷阱》本文主要介绍了Java中Integer与int的区别及装箱拆箱机制,重点指出-128至127范围内的Integer值会复用缓存对象,导致==比较结果为true,下... 目录一、Integer和int的联系1.1 Integer和int的区别1.2 Integer和in

SpringSecurity整合redission序列化问题小结(最新整理)

《SpringSecurity整合redission序列化问题小结(最新整理)》文章详解SpringSecurity整合Redisson时的序列化问题,指出需排除官方Jackson依赖,通过自定义反序... 目录1. 前言2. Redission配置2.1 RedissonProperties2.2 Red

IntelliJ IDEA2025创建SpringBoot项目的实现步骤

《IntelliJIDEA2025创建SpringBoot项目的实现步骤》本文主要介绍了IntelliJIDEA2025创建SpringBoot项目的实现步骤,文中通过示例代码介绍的非常详细,对大家... 目录一、创建 Spring Boot 项目1. 新建项目2. 基础配置3. 选择依赖4. 生成项目5.

JSONArray在Java中的应用操作实例

《JSONArray在Java中的应用操作实例》JSONArray是org.json库用于处理JSON数组的类,可将Java对象(Map/List)转换为JSON格式,提供增删改查等操作,适用于前后端... 目录1. jsONArray定义与功能1.1 JSONArray概念阐释1.1.1 什么是JSONA