XmlSerializer是不可能的。您可以使用PreserveObjectReferences属性使用DataContractSerializer实现此目的。您可以查看这篇解释详细信息的帖子。
这是一个示例代码:
public class Person{ public string Name; public Person Friend;}class Program{ static void Main(string[] args) { Person p1 = new Person(); p1.Name = "John"; Person p2 = new Person(); p2.Name = "Mike"; p1.Friend = p2; Person[] group = new Person[] { p1, p2 }; var serializer = new DataContractSerializer(group.GetType(), null, 0x7FFF , false , true , null ); serializer.WriteObject(Console.OpenStandardOutput(), group); }}
这将产生以下XML:
<ArrayOfPerson z:Id="1" z:Size="2" xmlns="http://schemas.datacontract.org/2004/07/ToDelete" xmlns:i="http://www.w3.org/2001/XMLSchema-instance" xmlns:z="http://schemas.microsoft.com/2003/10/Serialization/"> <Person z:Id="2"> <Friend z:Id="3"> <Friend i:nil="true"/> <Name z:Id="4">Mike</Name> </Friend> <Name z:Id="5">John</Name> </Person> <Person z:Ref="3" i:nil="true"/></ArrayOfPerson>
现在在构造函数中设置
PreserveObjectReferences为
false,您将获得以下信息:
<ArrayOfPerson xmlns="http://schemas.datacontract.org/2004/07/ToDelete" xmlns:i="http://www.w3.org/2001/XMLSchema-instance"> <Person> <Friend> <Friend i:nil="true"/> <Name>Mike</Name> </Friend> <Name>John</Name> </Person> <Person> <Friend i:nil="true"/> <Name>Mike</Name> </Person></ArrayOfPerson>
值得一提的是,以这种方式生成的XML不可互 *** 作,只能使用DataContractSerializer进行反序列化(与BinaryFormatter相同的说明)。
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)