2010-07-28 106 views
0

解決:下面的代碼不會導致無限循環,因爲我認爲。該循環在調用反序列化的代碼中。這個貼的代碼只是正常問題xml反序列化遞歸嵌套對象

我試圖序列化和反序列化到XML中的下列對象

public class MessageObjectCollection : List<MessageObject> 
{ 
    public string Serialize() 
    { 
     return XmlObjectSerializer.SerializeObject(this); 
    } 

    public static MessageObjectCollection DeSerialize(string serializedPriceHistory) 
    { 
     return XmlObjectSerializer.DeserializeObject<MessageObjectCollection>(serializedPriceHistory); 
    } 
} 

的MessageObject類看起來像這樣

public class MessageObject 
{ 
    public string Title; 
    public MessageObjectCollection Responses; 
} 

所以,如果我有一個實例messageobjectcollection看起來像:

var msgColl = new MessageObjectCollection 
    { 
     new MessageObject 
       { 
        Title = "Hello", 
        Responses = new MessageObjectCollection 
         { 
          new MessageObject 
            { 
             Title = "hi", 
             Responses = null 
            } 
         } 
       } 
    } 

我可以通過調用 var xml = msgColl.Serialize();

但是,當我試圖通過調用 反序列化這個var msgColl = new MessageObjectCollection()。Deserialize(xml);

我在反序列化方法得到一個堆棧溢出異常:

public static T DeserializeObject<T>(string xml) 
{ 
    T result; 
    var ser = new XmlSerializer(typeof(T)); 
    var buffer = StringToUTF8ByteArray(xml); 
    using (var stream = new MemoryStream(buffer, 0, buffer.Length)) 
    { 
     result = (T) ser.Deserialize(stream); 
    } 
    return result; 
} 

任何人都知道我做錯了嗎?

回答

0

林不知道,如果它的相關的問題,但作爲反序列化方法是靜態的你不應該叫...

var msgColl = MessageObjectCollection.Deserialize(xml); 

的,而不是...

var msgColl = new MessageObjectCollection().Deserialize(xml); 

+0

是的,你的權利當然。但這不是問題。這段代碼工作得很好,無限循環發生在這段代碼中,但是在調用反序列化的代碼中上游...... – 2010-07-28 12:57:12

+0

好吧,很高興你知道了。 – barrylloyd 2010-07-28 13:16:15