结果
在工作中常有用到redis,今天好奇测试了下在序列化存储对象快,还是JSON字符串的存储方式快。
先说结果,在多次使用1000次循环储存对象的测试中,储存对象比JSON要快5%左右。
使用环境
Java代码引用如下Jar包
<dependency>
<groupId>org.mybatis.spring.boot</groupId>
<artifactId>mybatis-spring-boot-starter</artifactId>
<version>2.1.3</version>
</dependency>
<dependency>
<groupId>com.alibaba</groupId>
<artifactId>fastjson</artifactId>
<version>1.2.75</version>
</dependency>
<dependency>
<groupId>com.fasterxml.jackson.core</groupId>
<artifactId>jackson-databind</artifactId>
<version>2.12.5</version>
</dependency>
测试代码
public void run(String... args) {
// 调用方法初始化一次,否则第一次会占用1秒左右时间初始化
for (int i = 0; i < 100; i++) {
redisTemplate.opsForValue().set("obj3",JSON.toJSONString(new Student("张三", "男")));
JSON.parseObject(redisTemplate.opsForValue().get("obj3").toString(),Student.class);
}
// JSON 存取
long start = System.currentTimeMillis();
for (int i = 0; i < 1000; i++) {
redisTemplate.opsForValue().set("obj1",JSON.toJSONString(new Student("张三", "男")));
Student t = JSON.parseObject(redisTemplate.opsForValue().get("obj1").toString(),Student.class);
}
System.out.println("字符串JSON时间:"+(System.currentTimeMillis() - start));
// 对象 存取
start = System.currentTimeMillis();
for (int i = 0; i < 1000; i++) {
redisTemplate.opsForValue().set("obj2",new Student("张三", "男"));
Student obj = (Student) redisTemplate.opsForValue().get("obj2");
}
System.out.println("序列化对象时间:"+(System.currentTimeMillis() - start));
}