c#出错:System.NullReferenceException: 未将对象引用设置到对象的实例

本文解析了System.NullReferenceException错误的常见原因及解决办法,涉及QueryString、Session、ViewState等对象使用时可能出现的问题。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

System.NullReferenceException: 未将对象引用设置到对象的实例

这个错误在以下代码中经常出现:

一、string id = Request.QueryString["XXX"].ToString();

二、string session = Session["XXXX"].ToString();

三、string viewState = ViewState["XXX"].ToString();

 

System.Data.SqlClient.SqlDataReader reader = "执行sql语句获取一个SqlDataReader对象";

四、string columnValue = reader["XXX"].ToString();

五、int columnInt = Convert.ToInt32(reader["XXXX"]);

           

六、string selectValue = DropDownList.SelectedValue.ToString();

总之这几个都是因为它们

Request.QueryString["XXX"]

Session["XXXX"]

ViewState["XXX"]

reader["XXX"]

DropDownList.SelectedValue

的值此时为null引起的。

另外注意:

一、Request.QueryString["XXX"]它的值本来就是string类型是不用再.ToString()进行转换的;

二、DropDownList.SelectedValue它的值本来也是string类型也是不用再.ToString()进行转换的;

三、int columnInt = Convert.ToInt32(reader["XXXX"])这行代码有两个地方需要留意:一是reader["XXXX"]不能为空这个空又有两个两个意思1是它的值不能等于null2是它的值不能为DBNull.Value。二是这个reader["XXXX"]的值要能够转换成int数据类型,否则会出现输入字符串格式不正确错误提示。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值