Serializable
查看官方文档就会发现,Serializable其实就是序列化
的体现。
其接口中一个成员函数或者成员变量也没有。public interface Serializable类通过实现 java.io.Serializable 接口以启用其序列化功能。未实现此接口的类将无法使其任何状态序列化或反序列化。可序列化类的所有子类型本身都是可序列化的。Serializable仅仅是用于标识可序列的语义,本身接口没有
- 作用
通过实现Serializable接口的类,该类所实例化的对象(实例变量)的状态信息在内存中可以持久化保存、传输,该过程称为序列化。与之相反的是,将序列化的结果变成对象的过程称为反序列化。
- 应用场景
- 对象的状态信息通过网络进行传输
- 需要将对象的状态信息持久化
- 注意
序列化时,只对对象的状态进行保存,而不管对象的方法;
当一个父类实现序列化,子类自动实现序列化,不需要显式实现Serializable接口
当一个对象的实例变量引用其他对象,序列化该对象时也把引用对象进行序列化
- 并非所有对象都可以序列化
- 安全方面的原因,比如一个对象拥有private,public等field,对于一个要传输的对象,比如写到文件,或者进行rmi传输 等等,在序列化进行传输的过程中,这个对象的private等域是不受保护的。
- 资源分配方面的原因,比如socket,thread类,如果可以序列化,进行传输或者保存,也无法对他们进行重新的资源分 配,而且,也是没有必要这样实现。