I'm confused - when should I be using XML Serialization and when should I be using Binary Serialization in the .NET framework?
Specific to .NET, If you have two applications that are using the same type system, then you can use binary serialization. On the other hand if you have applications that are in different platforms then it is recommended to use XML Serialization. So if i am writing a chat application (client and server), I might use binary serialization, but if I later decide that I should use Python to write a client, then I may not.
BinaryFormatter
(a specific example of a binary serializer) is a poor choice. There are several others. –
Fractocumulus Both of the existing answers focus on "cross platform", but that is an unrelated issue. The point they are making there is "don't use BinaryFormatter
if you are doing cross-platform" - which I entirely support. However there are a range of binary serialization formats that are very much cross-platform - protobuf / ASN.1 being prime examples.
So, let's look instead at what each has to offer;
- Binary is typically smaller, typically faster to process (at both ends), and not easily human readable / editable
- Text formats (xml / json) tend to be more verbose than binary (although often compresses well), but are pretty easy to work with by hand; but all that text processing an mapping tends to make them slower
- xml is very common is web-services, and benefits from gooling support such as xsd, xslt and robust xml editors
- json is the main player in browser-based comms (although it is also used in web-services) - tends to be less formal but still very effective
Notice how interoperability is neither a strength nor weakness of either, as long as you choose an appropriate binary format!
Here's an answer that compares the serialization time, deserialization and space metrics of most of the .NET serializers, for your reference.
Specific to .NET, If you have two applications that are using the same type system, then you can use binary serialization. On the other hand if you have applications that are in different platforms then it is recommended to use XML Serialization. So if i am writing a chat application (client and server), I might use binary serialization, but if I later decide that I should use Python to write a client, then I may not.
BinaryFormatter
(a specific example of a binary serializer) is a poor choice. There are several others. –
Fractocumulus If you want user friendly or cross platform output, then use XML. Also, XML serialization use public fields and properties to serialize and you can change/reformat output by using attributes and custom serialization on class level if you whant. Bin.Ser. uses private fields to serialize.
BinaryFormatter
is indeed a field serializer, it is not the only binary serializer - most others are far better behaved - and likewise, DataContractSerializer
writes xml, and unless the type is annotated correctly acts as a field serializer. –
Fractocumulus XmlSerializer
. "xml serialization" is simply a categorisation; XmlSerializer
is a specific example of an API for "xml serialization". DataContractSerializer
also performs "xml serialization". –
Fractocumulus © 2022 - 2024 — McMap. All rights reserved.