我制作了一个程序,按下按钮,程序崩溃了。 这是按钮的代码:
_alRecord.WriteXml(@".\alRecord.xml", XmlWriteMode.WriteSchema);
Debuging返回StackoverFlow(位置在注释中标记),以下是整个代码:
private string alFile = @".\alRecord.xml";
public DataTable alRecord;
public DataTable _alRecord
{
get
{ //location of stackoverflow
if (_alRecord == null)
{
alRecord = new DataTable();
if (File.Exists(alFile))
{ _alRecord.ReadXml(alFile); }
else
{ InitDataTable2(_alRecord); }
}
return _alRecord;
}
}
private void InitDataTable2(DataTable table)
{
table.TableName = "AlTable";
table.Columns.Add("ID", typeof(int));
table.Columns.Add("sun", typeof(bool));
table.Columns.Add("mon", typeof(bool));
table.Columns.Add("tue", typeof(bool));
table.Columns.Add("wed", typeof(bool));
table.Columns.Add("thu", typeof(bool));
table.Columns.Add("fri", typeof(bool));
table.Columns.Add("sat", typeof(bool));
table.Columns.Add("doors", typeof(string));
table.Columns.Add("from1", typeof(DateTime));
table.Columns.Add("to1", typeof(DateTime));
table.Columns.Add("from2", typeof(DateTime));
table.Columns.Add("to1", typeof(DateTime));
for (int i = 0; i < 99; i++)
{
var row = alRecord.NewRow();
row["ID"] = i;
row["sun"] = false;
row["mon"] = false;
row["tue"] = false;
row["wed"] = false;
row["thu"] = false;
row["fri"] = false;
row["sat"] = false;
row["doors"] = "";
row["from1"] = "00:01";
row["to1"] = "23:59";
row["from2"] = "00:01";
row["to2"] = "23:59";
alRecord.Rows.Add(row);
}
}
private void alSave_Click(object sender, EventArgs e)
{
_alRecord.WriteXml(@".\alRecord.xml", XmlWriteMode.WriteSchema);
}
答案 0 :(得分:4)
您从财产的吸气者手中打电话给您的财产:
public DataTable _alRecord
{
get
{
if (_alRecord == null) // <= whoops
这导致无限递归 - 调用属性的getter以查看它是否返回null调用属性的getter以查看它是否返回null调用属性的getter ...
@Dave在评论中提出了一个很好的观点 - 在c#中,通常使用属性为CasedLikeThis
的命名约定和后备字段(属性实际存储其值的字段为{{1它更容易区分 - 你总是知道_表示支持字段,反之亦然。