我正在尝试从已经保存的.xml文件中反序列化一个类。问题是,一旦我使用get{...} set{...};
代码抛出StackOverflow异常。我用这段代码创建一个无限循环吗?因为我无法通过暂停点跟踪循环。
班级:
[Serializable]
public class AddOn
{
[System.Xml.Serialization.XmlElement("Name")]
public string Name { set; get; }
[XmlIgnore]
public ProcessStartInfo Info {
set { Info = value; }
get {
Info.Arguments = args;
Info.Arguments = Path;
return Info;
}
}
[System.Xml.Serialization.XmlElement("Arguments")]
public string args { set; get; }
[System.Xml.Serialization.XmlElement("Path")]
public string Path { set; get; }
[XmlIgnore]
public List<Process> ChildProcess = new List<Process>();
public AddOn(string Name, ProcessStartInfo Info)
{
this.Name = Name;
this.Info = Info;
args = Info.Arguments;
Path= Info.FileName;
}
public AddOn() { }
}
[XmlIgnore]
public ProcessStartInfo Info {
set { Info = value; }
get {
Info.Arguments = args;
Info.Arguments = Path;
return Info;
}
}
get{...}
函数抛出StackOverflowException。
我忽略了ProcessStartInfo,因为我无法在第一时间序列化此类型,因此创建了两个字符串args和Path。
应该返回反序列化的插件列表的代码:
XmlSerializer serializer = new XmlSerializer(typeof(ObservableCollection<AddOn>));
StreamReader reader = new StreamReader(path);
var addons = (ObservableCollection<AddOn>)serializer.Deserialize(reader);
reader.Close();
return addons;
答案 0 :(得分:0)
此次电话
public ProcessStartInfo **Info** {
**set { Info = value; }**
get {
Info.Arguments = args;
Info.Arguments = Path;
return Info;
}
}
调用自身导致溢出