java.io.Serializabl序列化简单了解

参考文章:https://blog.csdn.net/so_geili/article/details/78931742

 

序列化(串行化 serialization):把一个对象的表示转化为字节流的过程。

反序列化(反串行化 deserialization):从字节流中把对象重建出来。


需要序列化场景:

  • 当你想把的内存中的对象状态保存到一个文件中或者数据库中,以便可以在以后重新创建精确的副本;
  • 当你想用套接字在网络上传送对象的时候(从一个应用程序域发送到另一个应用程序域中);
  • 当你想通过RMI(远程调用)传输对象的时候;

注意事项:

  • 序列化时,只对对象的状态进行保存,而不管对象的方法
  • 当一个父类实现序列化,子类自动实现序列化,不需要显式实现Serializable接口
  • 当一个对象的实例变量引用其他对象,序列化该对象时也把引用对象进行序列化
  • 并非所有的对象都可以序列化
  • 序列化会忽略静态变量,即序列化不保存静态变量的状态。静态成员属于类级别的,不能序列化。添加了static、transient关键字后的变量不能序列化。

序列化意义:

1)序列化就是一种用来处理对象流的机制,所谓对象流也就是将对象的内容进行流化,可以对流化后的对象进行读写操作,也可以将流化后的对象传输与网络之间;

2)为了解决对象流读写操作时可能引发的问题(如果不进行序列化,可能会存在数据乱序的问题)

3)序列化除了能够实现对象的持久化之外,还能够用于对象的深度克隆
 

你可能感兴趣的:(java小知识点)