什么是Java序列化,如何实现序列化

1 序列化概念

  • 序列化就是一个把Java对象编码成一串二进制的过程
    • 序列化的用途:可以将对象放入文件存储、或者放入网络传输
  • 反序列化就是一个解码的过程
  • 序列化没有固定的标准,有各种各样序列化的方法

Java自带序列化接口

  • 创建一个User类
  • 在main方法里创建User对象,通过ObjectOutputStream把对象写入到文件中
    • 编译报错
    • 因为该对象不能被序列化
  • 让User类实现 Serializable 接口
  • 把User对象写入到文件成功!
  • 我们发现写入后的文件大小比对象所有的属性值大很多
    • 因为java的Serializable会把类的继承体系也写到文件里,多了很多额外的信息
    • 会变得更臃肿,不利于大数据的数据在分布式系统中传输

    [Java] 纯文本查看 复制代码

    ?

    1

    2

    3

    4

    5

    6

    7

    private static void encoding() throws Exception {

        ObjectOutputStream os = new ObjectOutputStream(new FileOutputStream("E:/test/obj1.txt"));

        SerializableUser user = new SerializableUser();

        user.set("9521", "周星星", 23, 10000D);

        os.writeObject(user);

        os.close();

    }

  • [Java] 纯文本查看 复制代码

    ?

    1

    2

    3

    4

    5

    6

    7

    private static void decoding() throws Exception {

        ObjectInputStream oi = new ObjectInputStream(new FileInputStream("E:/test/obj1.txt"));

        Object object = oi.readObject();

        SerializableUser user = (SerializableUser) object;

        System.out.println(user);

        oi.close();

    }

自定义序列化(FileOutputStream)

  • 我们通过把对象的属性拼接成字符串
  • 通过 FileOutputStream 将字符串写入文件中
  • 写入后发现文件大小变小了很多(由150字节 --> 50字节)
    • 因为所有的属性都变成字符串格式,没有额外的信息
  • 反序列化的时候读取一行数据自己切割后放入对象
  • 存在一个问题,如果是一个Int类型的值,它变成字符串后字节长度变长了

将对象转成 json 格式再序列化

  • 通过把对象转成 json 格式序列化后可以很方便的对数据进行操作

[Java] 纯文本查看 复制代码

?

01

02

03

04

05

06

07

08

09

10

11

private static void encoding2() throws Exception {

    SerializableUser user = new SerializableUser();

    user.set("9521", "周星星", 23, 10000D);

    Gson gson = new Gson();

    String json = gson.toJson(user);

    System.out.println(json);

    FileOutputStream fos = new FileOutputStream("E:/test/obj2.txt");

    fos.write(json.getBytes("utf-8"));

    fos.flush();

    fos.close();

}

 

[Java] 纯文本查看 复制代码

?

1

2

3

4

5

6

7

8

private static void decoding2() throws Exception {

    BufferedReader br = new BufferedReader(new InputStreamReader((new FileInputStream("E:/test/obj2.txt"))));

    String json = br.readLine();

    br.close();

    Gson gson = new Gson();

    SerializableUser user = gson.fromJson(json, SerializableUser.class);

    System.out.println(user);

}


通过 DataOutputStream 优化上述代码

  • 将对象中的每一个属性按照它原来的类型进行逐个编码
    • 可以对基本数据类型按类型机制编解码
  • 我们通过 DataOutputStream 把属性一个一个写入到文件
  • 发现通过这种方式序列化后文件更加小了(再由50字节 --> 29字节)
  • 字符串在原来长度上多2个字符,用于表示字符串的边界

[Java] 纯文本查看 复制代码

?

01

02

03

04

05

06

07

08

09

10

11

12

13

private static void encoding3() throws Exception {

    SerializableUser user = new SerializableUser();

    user.set("9521", "周星星", 23, 10000D);

     

    DataOutputStream dos = new DataOutputStream(new FileOutputStream("E:/test/obj3.txt"));

    dos.writeUTF(user.getId());

    dos.writeUTF(user.getName());

    dos.writeInt(user.getAge());

    dos.writeDouble(user.getSalary());

     

    dos.flush();

    dos.close();

}

 

[Java] 纯文本查看 复制代码

?

01

02

03

04

05

06

07

08

09

10

11

12

13

private static void decoding3() throws Exception {

    SerializableUser user = new SerializableUser();

     

    DataInputStream dis = new DataInputStream(new FileInputStream("E:/test/obj3.txt"));

    String id = dis.readUTF();

    String name = dis.readUTF();

    int age = dis.readInt();

    double salary = dis.readDouble();

    user.set(id, name, age, salary);

    System.out.println(user);

     

    dis.close();

}


总结

  • Hadoop内部也有一套自己的序列化框架:提供了一个接口Writable
  • 我们的类只要实现了Writable接口,hadoop内部就能用自己的序列化机制去序列化这个类的对象


更多学习资料可关注:annalin1203获取

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: Java序列化是将Java对象转换为字节序列的过程,以便在网络上传输或将其保存到磁盘上。Java序列化可以将对象的状态保存到字节序列中,以便在需要时可以重新创建对象。Java序列化Java语言的一项重要功能,它使得Java对象可以在不同的平台和环境中进行传输和共享。 要实现Java序列化,需要让Java实现Serializable接口。Serializable接口是一个标记接口,它没有任何方法,只是用来标识一个类可以被序列化。当一个类实现了Serializable接口后,就可以使用Java序列化机制将其转换为字节序列。Java序列化机制可以通过ObjectOutputStream和ObjectInputStream类来实现。ObjectOutputStream类可以将Java对象转换为字节序列,而ObjectInputStream类可以将字节序列转换为Java对象。在序列化和反序列化过程中,需要注意对象的版本控制和安全性等问题。 ### 回答2: Java序列化是将Java对象转换为字节流的过程,以便在网络上传输或将它们保存到磁盘上。Java序列化提供了一种可移植、可扩展和安全的方法,可以将Java对象以一致的方式进行编码和解码。这样,数据可以在很多不同的平台上进行传输以及共享。 序列化的过程中,Java虚拟机将Java对象按照固定的协议进行打包和存储。Java序列化使用了一些内置的类和接口,如Serializable和Externalizable接口,以及ObjectInputStream和ObjectOutputStream类。 实现Java序列化需要以下步骤: 1. 让Java对象实现Serializable接口或Externalizable接口。这些接口是Java序列化机制的核心,在序列化和反序列化过程中起到关键的作用。 2. 创建一个输出流对象(ObjectOutputStream),将需要序列化Java对象写入到输出流中。 3. 创建一个输入流对象(ObjectInputStream),从输入流中读取序列化的字节流,并使用readObject()方法将其反序列化Java对象。 4. 处理序列化过程中可能会出现的异常,如IOException和ClassNotFoundException等。 Java序列化有许多用途,如在网络通信中进行数据传输、在分布式系统中传递Java对象、将Java对象保存到硬盘或数据库中等等。在某些应用中,序列化也被用作一种安全处理方式来对敏感数据进行加密和解密处理。 ### 回答3: Java序列化是指将Java对象转化为字节流。在计算机科学领域中,对象序列化通常用于在不同处理器上远程传输对象,或将对象持久存储到磁盘上。Java序列化的主要目的是在网络上传输和持久化存储对象,它将对象转换为字节流,以便在存储或传输过程中被转移。Java序列化机制具有自描述性,即在序列化过程中,不仅仅将对象数据写入输出流,还将对象的所有类型信息都保存在输出流中,所以反序列化后,不需要额外的类型信息。通过使用Java序列化机制,用户可以保存和加载对象的状态,而不需要程序员关注对象的细节。 在Java中,如果要将一个对象变成一个字节数组,就需要将该对象序列化Java序列化实现方法是使用ObjectOutputStream和ObjectInputStream类。要序列化一个Java对象,需要先创建一个ObjectOutputStream对象,并将要序列化的对象作为参数传递给它的构造函数。当调用writeObject()方法时,对象将会被序列化成一个字节数组。要反序列化一个Java对象,需要使用ObjectInputStream类,并通过readObject()方法获取反序列化后的对象。需要注意的是,被反序列化的对象必须和序列化时的对象类型一致。 一些需要使用Java序列化的场景包括:在网络上传输Java对象,当需要将Java对象在不同的应用程序之间传输时,可以使用Java序列化来容易地传递它们,比如在分布式系统和Web服务中;在Java应用程序之间传输Java对象,在Java应用程序之间传递Java对象时,也可以使用Java序列化来将Java对象序列化到一个字节数组中,然后将其传递给接收方;将Java对象持久地存储到磁盘上,使用Java序列化可以将Java对象写入磁盘并持久存储它们,以便在需要时可以读取它们。 总之,Java序列化是非常重要的。它提供了一种简单而强大的方式来在Java程序中传输和存储对象。实现Java序列化并不是很难,只需要使用ObjectOutputStream和ObjectInputStream类即可。然而,在应用序列化时,必须注意版本控制问题以及泛型类型安全性的问题,以避免在反序列化时出现问题。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值