在WCF服务中,我的情况是有一个datacontract(对象),其中包含一个子项集合(其中集合具有datamemeber属性)。子集合中的对象具有对父项的引用作为属性。如果父对象子集合为空或包含空父引用,则一切都很好,但如果填充父引用并填充父子代,则它将序列化为永远。
这是一组测试控制台代码,用于向您展示我正在谈论的内容。
class Program
{
static void Main(string[] args)
{
MyParentObject parent = BuildParent();
string xml = Serializer<MyParentObject>.Serialize(parent);
System.Console.Write(xml);
System.Console.ReadKey();
}
static MyParentObject BuildParent()
{
MyParentObject parent = new MyParentObject();
parent.MyParentObjectId = 123;
parent.MyParentObjectName = "Test Parent Object";
parent.MyChildren = new List<MyChildObject>();
for (int i = 0; i < 10; i++)
{
MyChildObject child = new MyChildObject();
child.MyParent = parent;
child.MyChildObjectId = i;
child.MyChildObjectName = string.Format("Test Child Name {0}", i.ToString());
parent.MyChildren.Add(child);
}
return parent;
}
}
[DataContract]
public class MyParentObject
{
[DataMember]
public int MyParentObjectId { get; set; }
[DataMember]
public string MyParentObjectName { get; set; }
[DataMember]
public List<MyChildObject> MyChildren { get; set; }
}
[DataContract]
public class MyChildObject
{
[DataMember]
public MyParentObject MyParent { get; set; }
[DataMember]
public int MyChildObjectId { get; set; }
[DataMember]
public string MyChildObjectName { get; set; }
}
public class Serializer<T>
{
public static string Serialize(T entity)
{
StringBuilder sb = new StringBuilder();
DataContractSerializer dcs = new DataContractSerializer(typeof(T));
using (XmlWriter writer = XmlWriter.Create(sb))
{
dcs.WriteObject(writer, entity);
writer.Flush();
}
return sb.ToString();
}
}
除了清除引起这种无限序列化循环的子/父引用之外,还有什么方法可以解决这个问题吗?
编辑:我知道我可以删除datamember属性,但是我想保留它,而不是无限地序列化。
答案 0 :(得分:4)
尝试在DataContract属性中使用IsReference属性
[DataContract(IsReference = true)]