分布式-序列化,反序列化

简介: 分布式-序列化,反序列化

1:序列化,反序列化得定义

序列化:序列化就是把一个对象变成二进制或者是一个有序的字节数组进行序列化来。

反序列化:把一个有序的字节流的对象重新加载为一个对象。

在分布式的中对程序的优化是非常重要的,只要在网络中进行 传输的话物理层之间的交互都需要序列化。

2:java中自带得序列化

让其序列化的类实现Serializable接口:缺点:1:它是不能实现跨语言的。2:序列化之后的文件大小很大。在网络中传输的带宽是很大的。在分布式中用的非常少。3:序列的时候没有实现这个接口就报错。

3:WebService得序列化

流量大的话:可以用WebService替代(SOAP协议),xml文件做传输介质的,用xml方式来做序列化的。在网络中进行传输。很长一段时间都是用webService作为序列化主流的。可以自己去扩展,可读性很强。很多的接口还是提供了XML文件的方式。因为 很多的老项目还在使用WebService去实现远程的调用。比如银行还在用,支付接口。主要作用,把远程的过程封装起来给你调用的接口,返回xml格式。

4:主流得框架来序列化:

针对java语言特有的:FST,Kryo(高性能的序列化框架)  

跨语言的序列化框架:jackson,fastson,protobuffer,protosutff,protobuf,gson。messagepack,avro(针对大数据的),thrift(rpc框架,也是序列化架),hessian2(dubbo原有的序列化方式)

现在dubbo开始支持的序列化框架也有FST和kryo了。

5:原生得序列化方式得序列化得代码如下

这个UUID代表这个类序列化的一种标识。也做为虚拟机的一种入口的验证,有点类似加密和解密。

然后同步一下idea:就出现这个的文件。

然后把这个文件拖到sublime里面去会显示:这就是二进制字节码。不是乱码 实际上它是二进制转成16进制的一个显示。这就是已经序列化到这个文件中去了。

6:进行一个反序列化:

7:运行结果如下:

8:打印下下三次次序列化后文件得大小

结论:每次增加得大小为5个字节,多次序列化,只是增加的是引用。不管序列化多少次,反序列化一次都能给它拿出。因为它会进行一个指针的拆分。在java虚拟机中做了一个这样的优化。这样的优化在后面的序列化框架中都有所呈现

在序列化中是否存在父子类序列化问题?比如说在父类中没有序列化,在子类中有序列化了。那么父类中的数据是否被序列化了呢?代码如下测试下:

public class Human {
    private  String  name;
    public String getName() {
        return name;
    }
    public void setName(String name) {
        this.name = name;
    }
    @Override
    public String toString() {
        return "Human{" +
                "name='" + name + '\'' +
                '}';
    }
}
import java.io.Serializable;
public class Person extends  Human implements Serializable {
    private String  gender;
    private int  age;
    public String getGender() {
        return gender;
    }
    public void setGender(String gender) {
        this.gender = gender;
    }
    public int getAge() {
        return age;
    }
    public void setAge(int age) {
        this.age = age;
    }
    @Override
    public String toString() {
        return "Person{name=" +getName()+","+
                "gender='" + gender + '\'' +
                ", age=" + age +
                '}';
    }
}
import java.io.*;
public class PersonDemoTest {
    public static void main(String[] args) throws Exception{
            Person person=new Person();
            person.setAge(12);
            person.setGender("男");
            person.setName("魏召阳");
            ObjectOutputStream oos=new ObjectOutputStream(new FileOutputStream("person-nav"));
            oos.writeObject(person);
            oos.flush();
            oos.close();
            ObjectInputStream ois=new ObjectInputStream(new FileInputStream("person-nav"));
            Person person1 =(Person)ois.readObject();
            System.out.println(person1);
    }
}

结论:说明父类中没有进行序列化,子类中序列化,并不影响父类中的数据,那么你在 但是它在这里不会报错的。如果父类去实现Serrialize接口的话:这时就可以拿到了。在dubbo中如果稍微不注意就会出现问题,因为dubbo中也有相关的协议,这些协议是很严格的。如果不按照协议的话,数据是传送不过去的。

相关文章
|
4月前
使用序列化和反序列化函数archivedDataWithRootObject和unarchivedObjectOfClasses的使用和遇到问题及解决方案
使用序列化和反序列化函数archivedDataWithRootObject和unarchivedObjectOfClasses的使用和遇到问题及解决方案
109 0
|
4月前
|
存储 C#
C#中的序列化和反序列化案例
C#中的序列化和反序列化案例
|
10月前
|
存储 JSON 缓存
|
前端开发 Shell 数据库
序列化使用
序列化使用
|
存储 Java
序列化
序列化
64 0
序列化与反序列化
序列化与反序列化
59 0
|
JSON IDE Java
浅谈序列化与反序列化
浅谈序列化与反序列化
浅谈序列化与反序列化
|
网络协议 Java 数据库
序列化系列(1)java序列化技术
这篇文章开始讲java对象的序列化,这是因为近期自己的项目当中,大量使用了序列化技术,这里面有java提供的序列化技术,也有一些序列化框架;所以,下定决心把java的序列化技术整理一下,以供参考。这是序列化系列的第一篇文章,所以主要是描述java提供的序列化技术。后续系列再分别讲使用框架实现序列化。 按照惯例,先给出这篇文章的大致脉络 首先,描述了序列化技术的使用场景和序列化的几种方案。 接着,讲java提供的序列化技术 然后,就是需要注意的几个问题,比如transient关键字、序列化ID的作用、深度克隆等等 最后,对java提供的系列化技术的一个总结
126 0
序列化系列(1)java序列化技术
|
存储 Java 数据库
什么是序列化
问题来了,什么是序列化呢?相信很多人都不太清楚,那我就把我的理解分享给大家
116 0
|
XML 存储 JSON
详解C# 序列化和反序列化
详解C# 序列化和反序列化
185 0
详解C# 序列化和反序列化