序列化:
简单说就是为了保存在内存中的各种对象的状态(也就是实例变量,不是方法),并且可以把保存的对象状态再读出来。虽然你可以用你自己的各种各样的方法来保存object states,但是Java给你提供一种应该比你自己好的保存对象状态的机制,那就是序列化。
序列化情况:
- 当你想把的内存中的对象状态保存到一个文件中或者数据库中时候。
- 当你想用套接字在网络上传送对象的时候。
- 当你想通过RMI传输对象的时候。
注意点:
- 当一个对象被序列化时,只对对象的状态进行保存;只保存对象的非静态成员变量,不能保存任何的成员方法和静态的成员变量。
- 如果一个对象的成员变量是一个对象,那么这个对象的数据成员也会被保存。
- 如果一个可序列化的对象包含对某个不可序列化的对象的引用,那么整个序列化操作将会失败,并且会抛出一个NotSerializableException。我们可以将这个引用标记为transient,那么对象仍然可以序列化。
- 还有就是对某个对象进行序列化时,往往对整个对象全部序列化,比如说类里有些敏感数据不希望序列化,一个方法可以用transient来标识,另一个方法可以在类里重写readObject和writeObject。