原创

Java类实现Serializable的作用

温馨提示:
本文最后更新于 2022年11月15日,已超过 522 天没有更新。若文章内的图片失效(无法正常加载),请留言反馈或直接联系我

一个类只有实现了Serializable接口,它的对象才是可序列化的。因此如果要序列化某些类的对象,这些类就必须实现Serializable接口。而实际上,Serializable是一个空接口,没有什么具体内容,它的目的只是简单的标识一个类的对象可以被序列化。

需要序列化的场景

a. 当你想把的内存中的对象写入到硬盘的时候。

比如说你的内存不够用了,那计算机就要将内存里面的一部分对象暂时的保存到硬盘中,等到要用的时候再读入到内存中,硬盘的那部分存储空间就是所谓的虚拟内存。在比如过你要将某个特定的对象保存到文件中,我隔几天在把它拿出来用,那么这时候就要实现Serializable接口。

b. 当你想用套接字在网络上传送对象的时候。

在进行Java的Socket编程的时候,你有时候可能要传输某一类的对象,那么也就要实现Serializable接口。最常见的你传输一个字符串,它是JDK里面的类,也实现了Serializable接口,这样做为的是将数据变为二进制来传输,所以可以在网络上传输。

c. 当你想通过RMI传输对象的时候。

如果要通过远程的方法调用(RMI)去调用一个远程对象的方法,如在计算机A中调用另一台计算机B的对象的方法,那么你需要通过JNDI服务获取计算机B目标对象的引用,将对象从B传送到A,就需要实现序列化接口。

示例说明

@Entity
@Table(name = "user")
public class User implements Serializable{
    private int userId;
    private String userName;
    ……
}

如果没有用implements Serializable时,User对象封装数据储存到数据库,需要时取出,即使SQL在数据库中正确返回数据,但sessionFactory.getCurrentSession().createNativeQuery(SQL,User.class).list()返回的数据中字段内容都是空(数据条数正常不受影响),从而会导致注入方法抛出javax.persistence.PersistenceException等异常错误。

Serializable序列化总结一下就是保证数据准确的存入或者读取。

正文到此结束
该篇文章的评论功能已被站长关闭
本文目录