I have a client and a server application which communicate over .NET 2.0 Remoting using binary serialization.
A small change has been made to one of the data transfer object's interface and the implementing class, well, an array of strings field was added.
If I to redeploy a new version of server application, will my old clients continue to work?
I would think they would, since nothing has been deleted from interface and direct implementation, but I am not sure.
It probably boils down to another question - is a binary deserialiser "clever enough" to handle the situation like this by initializing a fields it fails to find data in the input binary stream to null, or is it going to break and to throw the exception?
More than likely it is going to throw an exception, you could always implement your own Serializer by inheriting from
ISerializable
and implement the versioning by using your own methods ofGetObjectData
...this will give you a tighter degree of control over the data to be serialized...Here's an exampleAnd use MyFooBar in this context when serializing/deserializing as shown below
There is a more neater way to do this in 2.0+ upwards, but I prefer this way.
You can add an attribute to the new property:
OptionalField
. Without the attribute, the deserializer will not be able to convert serialized data back to the updated definition. The attribute is to ensure the deserializer can handle the "missing" data gracefully.If you want to set a default value for the new property, in the case that no appropriate data for it is deserialized, implement the
IDeserializationCallback
interface, and set the default value, if any, in the resulting method.