这取决于场景。
XmlSerializer当然是一种方法,并且具有直接映射到对象模型的优势。在.NET 3.5
Xdocument等方面也非常友好。如果尺寸很大,那
XmlWriter就是您的朋友。
对于一个
Xdocument例子:
Console.WriteLine( new XElement("Foo", new XAttribute("Bar", "some & value"), new XElement("Nested", "data")));
或与
Xmldocument:
Xmldocument doc = new Xmldocument();XmlElement el = (XmlElement)doc.AppendChild(doc.CreateElement("Foo"));el.SetAttribute("Bar", "some & value");el.AppendChild(doc.CreateElement("Nested")).InnerText = "data";Console.WriteLine(doc.OuterXml);
如果您正在写入 大量 数据,那么任何DOM方法(例如
Xmldocument/
Xdocument等)都将迅速占用大量内存。因此,如果您要从CSV编写一个100
MB的XML文件,则可以考虑
XmlWriter;这是更原始的(一次写入型firehose),但是非常有效(在这里想象一个大循环):
XmlWriter writer = XmlWriter.Create(Console.Out);writer.WriteStartElement("Foo");writer.WriteAttributeString("Bar", "Some & value");writer.WriteElementString("Nested", "data");writer.WriteEndElement();
最后,通过
XmlSerializer:
[Serializable]public class Foo{ [XmlAttribute] public string Bar { get; set; } public string Nested { get; set; }}...Foo foo = new Foo{ Bar = "some & value", Nested = "data"};new XmlSerializer(typeof(Foo)).Serialize(Console.Out, foo);
这是映射到类等的不错模型。但是,如果您执行简单的 *** 作(或者所需的XML确实与对象模型没有直接关联),则可能会过大。另一个问题
XmlSerializer是,它不喜欢序列化不可变类型:所有内容都必须具有公共的getter
和
setter(除非您自己通过实现来完成所有工作
IXmlSerializable,在这种情况下,您使用不会有太多收获
XmlSerializer)。
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)