前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >fastjson:javabean按字段(field)序列化存储为Map并反序列化改进

fastjson:javabean按字段(field)序列化存储为Map并反序列化改进

作者头像
10km
发布2018-01-03 11:57:18
1.5K0
发布2018-01-03 11:57:18
举报
文章被收录于专栏:10km的专栏10km的专栏

需求说明

最近的项目应用到redis数据库,需要将java bean存储在redis数据库。因为需要对数据库中的某个字段进行修改,所以在redis上不能用简单的string类型存储,而要以hash类型存储。这就需要在向数据库写入java bean对象之前要将java bean按字段序列化为一个Map<String,String>

而在从数据库读取后,又需要将所有字段合并反序列化还原成一个java bean对象。

上一篇博客《fastjson:javabean按字段(field)序列化存储为Map并反序列化》实现了 java bean按字段序列化和反序列化,但在文章结尾总结时也说明了这种方式的缺点,就是存在反复序列化的过程,会在一定程度上影响效率,不够完美。

刚才进一步研究了fastjson的代码,找到了更好的方案,减少序列化过程。

序列化

实现步骤:

1.用JSON.toJSON(Object)将java bean解析为JSONObject对象(其实也是一个Map<String,Object>,JSONObject实现了Map接口).

2.对上一步中的JSONObject中每个字段调用JSON.toJSONString(Object)进行序列化,最终生成符合redis数据库hash类型存储要求的Map<String,String>

与前文《fastjson:javabean按字段(field)序列化存储为Map并反序列化》的方法相比,只有两个步骤,没有多余的序列化和反序列化过程。

反序列化

反序列化阶段与与前文《fastjson:javabean按字段(field)序列化存储为Map并反序列化》的方法相同

实现步骤:

1.从redis获取所有字段数据,也就是一个Map<String,String>.对Map中每个字段的json string调用 JSON.parse(String)反序列化,生成一个Map<String,Object>,其中的Object就是字段反序列化生成的对象

2.调用 com.alibaba.fastjson.util.TypeUtils.cast(Object , Type , ParserConfig)方法将上一步的Map<String,Object>还原为java bean对象

实现代码及测试

代码语言:javascript
复制
package net.gdface.facelog.message;

import java.lang.reflect.ParameterizedType;
import java.lang.reflect.Type;
import java.util.ArrayList;
import java.util.Date;
import java.util.HashMap;
import java.util.List;
import java.util.Map;
import java.util.Map.Entry;

import org.junit.Test;

import com.alibaba.fastjson.JSON;
import com.alibaba.fastjson.TypeReference;
import com.alibaba.fastjson.serializer.SerializerFeature;

public class TestFastjson {


    @Test
    public void testJSONObject() {
        Group group = new Group();
        group.setId(0L);
        group.setName("admin");

        User guestUser = new User();
        guestUser.setId(2L);
        guestUser.setName("guest");

        User rootUser = new User();
        rootUser.setId(3L);
        rootUser.setName("root");

        group.addUser(guestUser);
        group.addUser(rootUser);
        {
            ////////// 按字段序列化 ///////////////
            // 序列化步骤1
            JSONObject jsonObject = (JSONObject) JSON.toJSON(group);
            Map<String, String> jsonObj = new HashMap<String, String>();
            // 序列化步骤2
            for (Entry<String, Object> entry : jsonObject.entrySet()) {
                Object value = entry.getValue();
                if(null !=value){
                    String jsonValue=JSON.toJSONString(value);
                    jsonObj.put(entry.getKey(), jsonValue);
                }
            }
            ////////// 按字段反序列化 ///////////////
            // 反序列化步骤1
            Map<String, Object> deJsonMap = new HashMap<String, Object>();
            for (Entry<String, String> entry : jsonObj.entrySet()) {
                String json = (String) entry.getValue();
                String key = entry.getKey();
                Object field = JSON.parse( json);
                deJsonMap.put(entry.getKey(), field);
            }
            // 循环结束时 Map<String, Object>中的每个字段对应的Object都是反序列化后的对象
            // 反序列化步骤2
            Group dgroup = com.alibaba.fastjson.util.TypeUtils.cast(deJsonMap, Group.class, null);
            System.out.println(JSON.toJSONString(dgroup));
        }       
    }
    public interface Person<T>{

    }
    public static class User implements Person<String>{

        private Long   id;
        private String name;


        public Long getId() {
            return id;
        }

        public void setId(Long id) {
            this.id = id;
        }

        public String getName() {
            return name;
        }

        public void setName(String name) {
            this.name = name;
        }

    }
    public static  class Group {

        private Long       id;
        private String     name;
        private List<User> users = new ArrayList<User>();
        public Date date=new Date();
        public java.sql.Date sqldate=new java.sql.Date(date.getTime());
        public byte[] array=new byte[]{22,33,3,2,3,1,5,-1};
        public String nullStr=null;
        private String privString="private string";
        public Long getId() {
            return id;
        }

        public void setId(Long id) {
            this.id = id;
        }

        public String getName() {
            return name;
        }

        public void setName(String name) {
            this.name = name;
        }

        public List<User> getUsers() {
            return users;
        }

        public void setUsers(List<User> users) {
            this.users = users;
        }

            public void addUser(User user) {
                users.add(user);
            }
    }
}

注意

《fastjson:javabean按字段(field)序列化存储为Map并反序列化》的方法(简称方法1)相比,这种方式序列化出的json string是不同的。

比如对于byte[]类型方法1会序列成base64格式的字符串"FiEDAgMBBf8="

而本方法则会序列化成json数组[22,33,3,2,3,1,5,-1],显然方法1对byte[]类型序列化的字符串体积要小。

总而言之,方法1序列化的字符串与用JSON.toJSONString(Object)方法对java bean整体序列化的结果保持一致。而本方法序列化的结果则不会。

本文参与 腾讯云自媒体分享计划,分享自作者个人站点/博客。
原始发表:2017年09月10日,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 需求说明
  • 序列化
  • 反序列化
  • 实现代码及测试
  • 注意
相关产品与服务
数据库
云数据库为企业提供了完善的关系型数据库、非关系型数据库、分析型数据库和数据库生态工具。您可以通过产品选择和组合搭建,轻松实现高可靠、高可用性、高性能等数据库需求。云数据库服务也可大幅减少您的运维工作量,更专注于业务发展,让企业一站式享受数据上云及分布式架构的技术红利!
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档