开发者

Java:Immutability and serialization

开发者 https://www.devze.com 2023-03-17 19:28 出处:网络
When I have an immutable parent class A that is NOT final, and another class B extends it(B is mutable), is there any way the immutability of A c开发者_运维知识库an be affected because of serializatio

When I have an immutable parent class A that is NOT final, and another class B extends it(B is mutable), is there any way the immutability of A c开发者_运维知识库an be affected because of serialization?

I wrote a small program to serialize an object, changed its state in the program, and then de-serialized it. I got the object back in the form in which it was serialized. So I am wondering is there any way I can alter A's immutability by serializing it?


It depends on exactly what you are asking. If you just want to get a different value back than what you put in, then yes, you can do that through serialization. The serialized data is completely detached from the instance of A that exists in memory. When Java reconstructs an object from the serialized data, it doesn't know or care anything about the original instance of A that was used to create that data. It is simply constructing a data-structure in memory based off of the blueprint provided in the serialized information.

So if you want to modify what you get back when you reconstruct A, you can do so by manually modifying the binary serialized data. Doing so will require a good understanding of Java's serialization format, but it can certainly be done.

Though if you are asking if there is any way to modify the original instance of A through serialization (as in, to somehow get the same object to change in value, without constructing a new instance via deserialization), then the answer is no, you cannot. Serialization simply creates a snapshot of the object's current state. Deserialization creates a new object instance that is completely detached from the source instance. So while you might manually change the value, the new object with the new value will still be immutable once it has been deserialized.

And if you are asking if there a way to serialize an instance of immutable class A and then deserialize the data as something that identifies as an instance of class A but happens to be mutable then the answer is also no. The serialized data specifies what class of object is being represented, but the class definition itself is not serialized. So you could change the specified class such that you serialize an instance of A and then deserialize an instance of mutable class B, but that's not the same as getting back a mutable instance of A.


You can't alter its immutability (the class will still be immutable) but you can alter its values by editing the serialized information.

You can also alter it through reflection, immutable isn't some kind of magic protection, it's just creating a class without mutators to help overal program stability. Although variables should probably be final, that's not even necessary--to be immutable you simply have to always return the same value for all of your methods.

Anyway, if you are going to extend an immutable class, you probably want your extension to be immutable as well--if not chances are you don't really want to extend the class, perhaps you just want to encapsulate it (is there an is-a relationship or a has-a?)


When you serialise an object, that object does not change whether it is immutable or not.

When you de-serialise a new object, its is a reconstruction of the first object based on the information recorded and how you do the de-serialisation.

For example, if you have an immutable class and a field is transient, the de-serialised copy will not have that field set (you made it transient)

0

精彩评论

暂无评论...
验证码 换一张
取 消