我有类 SellStatement
public class SellStatement
{
public long billNo
public DateTime paymentDate;
public List<string> ProductName;
public List<double> quantity;
public List<double> ratePerQuantity;
}
当我尝试访问函数 GetSaleDetails
public Exception GetSaleDetails(List<SellStatement> lss1,string query)
{
try
{
for (int i = 0; i < lss1.ToArray().Length; i++)
{
query = "select * from [product details] where [bill no]=@billno";
com = new SqlCeCommand(query, con);
con.Open();
com.Parameters.AddWithValue("@billno",lss1[i].billNo);
sdr = com.ExecuteReader();
while (sdr.Read())
{
lss1[i].ProductName.Add(sdr.GetString(1));//Exception line
lss1[i].quantity.Add(sdr.GetDouble(2));
lss1[i].ratePerQuantity.Add(sdr.GetDouble(3));
}
}
con.Close();
return null;
}
catch (Exception e)
{
con.Close();
return e;
}
}
Null Reference Exception 出现在lss1[i].ProductName.Add(sdr.GetString(1));
。我认为错误可能是由于 at 中的 null 值,sdr.GetString(1)
但我检查了它有一些值。我的朋友告诉我,你不能像这样更改 Function 参数值,所以我尝试将一个列表复制到另一个像这样 。
List<SellStatement> lss1 = new List<SellStatement>() ;
lss1.AddRange(lss);
但这对我没有帮助。添加元素时我无法弄清楚出了什么问题。