我想序列化和反序列化这样的对象:
public class Root
{
public string title;
[XmlArray("lista")]
[XmlArrayItem("Parameter")]
public List<Parameter> lista;
}
public class Parameter : IXmlSerializable
{
public string name;
public int val;
public void WriteXml(XmlWriter writer)
{
writer.WriteElementString("name",name);
writer.WriteElementString("val",val.ToString());
}
public void ReadXml(XmlReader reader)
{
reader.ReadToDescendant("name");
name = reader.ReadElementContentAsString();
val = reader.ReadElementContentAsInt();
}
public XmlSchema GetSchema()
{
return (null);
}
}
问题是当我反序列化这个对象时,它只添加了列表的第一个元素。例如:
序列化:
<Root>
<title>title</title>
<lista>
<Parameter>
<name>pa</name>
<val>1</val>
</Parameter>
<Parameter>
<name>pb</name>
<val>2</val>
</Parameter>
</lista>
</Root>
反序列化:
<Root>
<title>title</title>
<lista>
<Parameter>
<name>pa</name>
<val>1</val>
</Parameter>
</lista>
</Root>
我意识到了一个Fiddle例子。 有人能帮助我吗?
答案 0 :(得分:4)
您只是在RealXml方法的末尾读取第一个要添加reader.Read();
的元素来创建循环:
public void ReadXml(XmlReader reader)
{
reader.ReadToDescendant("name");
name = reader.ReadElementContentAsString();
val = reader.ReadElementContentAsInt();
reader.Read();
}
但如果您没有特定原因,则不需要实施IXmlSerializable
。
您只需使用XmlSerializer
,如下所示:
XmlSerializer serializer = new XmlSerializer(typeof(Root));
StringBuilder result = new StringBuilder();
using (var writer = XmlWriter.Create(result))
{
serializer.Serialize(writer, root); /// serialize
}
using (var reader = new StringReader(result.ToString()))
{
var deserialized = (Root)serializer.Deserialize(reader); //// deserialize from string
}
答案 1 :(得分:0)
如果您不必使用自定义序列化程序,将Parameter类更改为以下内容可以解决问题(在您的小提琴示例中测试过):
public class Parameter
{
public string name {get;set;}
public int val {get;set;}
}