在此行运行c#代码后,我收到了nullrefernce异常
var data = info.details.Split('|');
c#code:
public studentinfo SaveData(studentinfo info)
{
bool returnBool=false;
SqlConnection con;
var data = info.details.Split('|');
var response = new studentinfo
{
ID = data[0],
Name = data[1],
Project = data[2],
Result = data[3]
};
con = new SqlConnection(ConfigurationManager.ConnectionStrings["Myproject.Properties.Settings.MyConnection"].ConnectionString);
string sqlStr = "INSERT INTO Result (ID,Name,Project,Result) values('" + data[0] + "', '" + data[1] + "', '" + data[2] + "', '" + data[3] + "')";
SqlCommand dbCommand = new SqlCommand(sqlStr, con);
try
{
con.Open();
if (dbCommand.ExecuteNonQuery() != 0)
{
returnBool = true;
}
if (!data.Equals(null))
{
returnBool = true;
}
con.Close();
}
catch
{
returnBool= false;
}
con.Close();
return response;
}
我试图实施:
if (!data.Equals(null))
{
returnBool = true;
}
但即便如此它给出了相同的对象引用异常,请帮我解决一下。 感谢
答案 0 :(得分:3)
试试这个
if(data != null)
{
}
或者
if(object.ReferenceEquals(data,null))
{
}
可能@zigdawgydawg指出异常不会检查data
因为string.Split
永远不会返回null
。所以,你需要避免使用null参数。
if(info==null || info.details == null)
{
return null;//Or throw new ArgumentException();
}
答案 1 :(得分:2)
Null引用异常是因为info
或info.details
为空。在执行Split
之前,您需要检查空值。
答案 2 :(得分:0)
在尝试字符串拆分
之前,需要检查nullif (info == null)
{
// do not attempt to split details, maybe throw something here
}
但是,您可能希望了解如何调用SaveData(studentinfo info)
,以及在什么情况下传递null studentinfo
对象。