我有这段代码:
public List<CsvUserData> CsvUserList = new List<CsvUserData>();
public CsvUserData()
{
readCSV(@"C:\userdata.csv");
}
public string CSVEmailEditText { get; set; }
public string CSVNameEditText { get; set; }
public string CSVAddressEditText { get; set; }
public string CSVPostnumEditText { get; set; }
public string CSVCityEditText { get; set; }
public string CSVPhoneEditText { get; set; }
public string CSVCommentEditText { get; set; }
public string SelectPage { get; set; }
private void readCSV(string location)
{
var reader = new StreamReader(File.OpenRead(location));
string line;
string[] values;
while (!reader.EndOfStream)
{
line = reader.ReadLine();
values = line.Split(',');
CsvUserList.Add
(
new CsvUserData
{
CSVEmailEditText = values[0],
CSVNameEditText = values[1],
CSVAddressEditText = values[2],
CSVPostnumEditText = values[3],
CSVCityEditText = values[4],
CSVPhoneEditText = values[5],
}
);
}
}
我正在尝试将csv
文件读入由名为CsvUserData
的对象组成的列表中,上面显示了类定义。一旦类被实例化,我的程序进入无限循环,一旦列表内存已满,最终导致stackoverflow
异常,即使我的csv文件只有一行数据。有人可以帮助我并解释为什么会这样吗?
答案 0 :(得分:5)
让我们看看:
CsvUserData
对象,调用构造函数。readCSV(@"C:\userdata.csv");
readCSV
:打开文件,然后遍历各行。new CsvUserData { … }
因此,您最终会在 CsvUserData
类型的构造函数中的中创建新的CsvUserData
个对象。所以这将永远重复。
您可能打算将readCSV
方法设为静态或其他方式,并且只将其称为一次。实际上没有理由从构造函数中调用它。并且构造函数不应该真正打开文件并根据文件创建东西;这对构造函数来说太过分了。