问题
We have an application with objects that we'd like to keep serialized in the database.
Currently we're using NetDataContractSerializer
, but recently found out that due to the .Net
types information involved, it creates huge files which means slow application, even for basic objects.
We're considering switching to DataContractSerializer
instead, and I've been looking for a nice comparison of the two but didn't find one.
- What's the difference in sizes between the objects created by the two?
- Is there a big performance difference?
- Is any of them problematic when I have an object that contains a
List<X>
, whereX
is inherited by multiple other objects, so that the list contains many different types at runtime? (I was told thatDataContractSerializer
can be givenKnownTypes
attributes, but this means more dependencies in the code. Is there a way to makeDataContractSerializer
know all that types in my solution?)
Thanks.
回答1:
- NetDataContractSerializer (NetDCS) writes the type information for all objects, while the DataContractSerializer (DCS) only writes those which need to (i.e., if you declare a member as type B, and the actual value of the member when being serialized is of type D, where D is a derived type from B, so there is a lot less "noise" in a DCS-serialized type.
- Not really, but you should try both with your scenario to see if it will affect you
- You need to use known types in the DCS, but you can use a
DataContractResolver
if you don't want to work with known types. An example of such a resolver can be found in Youssef Massaoui's blog, and some more information on the resolver itself can be found at my post on WCF extensibility at http://blogs.msdn.com/b/carlosfigueira/archive/2011/09/21/wcf-extensibility-data-contract-resolver.aspx.
来源:https://stackoverflow.com/questions/7890693/netdatacontractserializer-vs-datacontractserializer