代码改变世界

关于“System.NullReferenceException: 未将对象引用设置到对象的实例”问题原因。

2013-02-17 16:50  糯米粥  阅读(32189)  评论(0编辑  收藏  举报

来自网络。收集并整理。

今天又遇到"未将对象引用设置到对象的实例",敲代码的多多少少遇到过改异常吧。既然遇到了索性就在网络上收集一些引起该错误的罪魁祸首:

1ViewState 对象为Null
2
DateSet 空。
3
sql语句或Datebase的原因导致DataReader空。
4
、声明字符串变量时未赋空值就应用变量。
5
、未用new初始化对象。
6
Session对象为空。
7
、对控件赋文本值时,值不存在。
8
、使用Request.QueryString(),所获取的对象不存在,或在值为空时未赋初始值。
9
、使用FindControl,控件不存在却没有做预处理。
10、重复定义造成未将对象引用设置到对象的实例错误。


示例1:

 这个函数比如容易看的出:如果value传进来为Null的时候,就等于Null.Replace被调用,就出现了上面的错误。
因此,通常的,在函数的首行,都会对value进行:if(!string.IsNullOrEmpty(value)) 一下。

public static string FilterValue(string value) 
{ 
  string[] filterChar = new string[] { "\'", ",", ">", "<", "=", ";", "\"", "--" }; 
  for (int i = 0; i < filterChar.Length; i++) 
  { 
    value = value.Replace(filterChar[i], ""); 
  } 
  return value.Trim(' '); 
} 

 

示例2:

  绑定,Eval("字段") ,这个方法比较常见,某些情况要转字符串比较

    <%# Eval("字段").ToString()=="1"?"Yes":"No" %>

  当Eval("字段")为Null时,一个Null.ToString(),必然也会出现上面的错误,那什么情况出现? 
  1:字段的值为Null
  2:空数据行,就是你表一行数据都没有,全是Null。 

 所以预防性的写法是:

    <%# Convert.ToString(Eval("字段"))=="1"?"Yes":"No" %>