这是另一个question的延续,可以找到与此问题相关的所有代码,Here。我遇到了一个奇怪的NullReferenceException错误,我无法弄清楚。我正在尝试从反序列化的Web响应中构建一个表。当我去遍历对象项目时,我点击了NRE。奇怪的是我通过它自己测试了我的条件陈述,我能够抓住它。这是我的代码:
public string getExample()
{
DataTable dt = new DataTable();
XmlSerializer serializer = new XmlSerializer(typeof(WeeklyJobs));
WeeklyJobs jobs;
string xml = @"<?xml version = ""1.0""?>"
+ @"<WeeklyJobs>"
+ @"<DailyJobs Date = ""02/03/2012""/>"
+ @"<DailyJobs Date = ""02/04/2012"" TotalJobs = ""2"">"
+ @"<Jobs>"
+ @"<Job JobName = ""Job Name"" Description = ""Description""/>"
+ @"<Job JobName = ""Job Name"" Description = ""Description""/>"
+ @"</Jobs>"
+ @"</DailyJobs>"
+ @"<DailyJobs Date = ""02/05/2012"" TotalJobs = ""1"">"
+ @"<Jobs>"
+ @"<Job JobName = ""Job Name"" Description = ""Description""/>"
+ @"</Jobs>"
+ @"</DailyJobs>"
+ @"<DailyJobs Date = ""02/06/2012"" TotalJobs = ""2"">"
+ @"<Jobs>"
+ @"<Job JobName = ""Job Name"" Description = ""Description""/>"
+ @"<Job JobName = ""Job Name"" Description = ""Description""/>"
+ @"</Jobs>"
+ @"</DailyJobs>"
+ @"<DailyJobs Date = ""02/07/2012""/>"
+ @"</WeeklyJobs>";
// Create an XmlTextReader
using (XmlReader reader = XmlReader.Create(new StringReader(xml)))
{
jobs = (WeeklyJobs)serializer.Deserialize(reader);
}
// Create Table
dt.Columns.Add("Date");
dt.Columns.Add("JobName");
dt.Columns.Add("Description");
for (int i = 0; i < jobs.Items.Length; i++ )
{
DataRow dr;
object[] rowItems = null;
rowItems[0] = jobs.Items[i].Date;
if(jobs.Items[i].Jobs == null || jobs.Items[i].Jobs.Length == 0) //NRE is thrown Here <--
{
rowItems[1] = "";
rowItems[2] = "";
}
else
{
foreach (WeeklyJobsDailyJobsJobsJob job in jobs.Items[i].Jobs)
{
rowItems[1] = job.JobName;
rowItems[2] = job.Description;
}
}
dr = dt.NewRow();
dr.ItemArray = rowItems;
dt.Rows.Add(dr);
}
return dt.Rows.Count.ToString();
}
现在这是我无法弄清楚的部分。当我注释掉Create Table代码并在我知道的项上添加if语句为null时,条件正确处理它。这是我在评论出创建表代码后添加的内容:
if(jobs.Items[0].Jobs == null)
{
return "null";
}
else
{
return jobs.Items[0].Jobs.Length.ToString();
}
它返回“null”。我不确定发生了什么。也许我的for循环没有正确设置?谢谢你的帮助!
答案 0 :(得分:2)
你知道,我经常看到调试器将执行点放在异常后的行上,当它发生故障时。
也许这是你的问题:
object[] rowItems = null;
rowItems[0] = jobs.Items[i].Date;
NRE由空数组上的索引器调用抛出。