代码改变世界

周一深说--未将对象引用设置到对象的实例(System.NullReferenceException)

2011-07-25 13:36  白面青铜  阅读(562)  评论(3编辑  收藏  举报

1. 异常:

        "未将对象引用设置到对象的实例"


2. 本质

    1). 字符串的空引用.

    2). 空对象的空引用.

3. 解决方案I:

      简单直白:在所有引用地方判断

       . if(!string.IsNullOrEmpty(User.UserName))

       .if(null!=User)

      点评:  面向过程开发的思维.

       A.这种办法看起来确实像一个很有经验的老鸟写的代码,不错,没有任何问题.但事实上只能称得上细心,与"菜"和"老"一点关系也没有. 就好像有人告诉你:这地方有雷,不能踩. 所有的人都会绕过去的,除非傻子.

      B. 看起来很稳定可靠,其实是最不可靠的:比如

          User类有N个字符串属性: UserName,NickName,Address...

          一个方法中都用到了则要:  if(!string.IsNullOrEmpty(User.UserName) && !string.IsNullOrEmpty(User.NickName).......)

         这是一个非常有看点的一行代码,别说人的精力有限,神仙也难保证在一个上十万行代码里面每个地方都判断,致命的一点是这个代码不是你一个写,你能保证每人都不是你认为的傻子吗?老板肯会花重金全部招聘老鸟?

       C. 最终的结果:   XXX代码规范.doc中的"每个引用前要判空的"的规范形同虚设,空引用的异常隔三叉五的跑出来,老板经常跳出来骂人.

      

 4. 解决方案II.

       先具备个基本素质:理解面向对象编程. 理解设计模式.

       底层保证不返回空串,而是返回空白串.

       底层保证不返回空对象,而是空白对象.

       最外层逻辑用Try Catch

      点评:

           A. 解决99%的空引用,除非你一定要用空引用异常来做为业务逻辑.

           B. 相当可靠,除非你故意给一个对象主动设置为NULL.

           C. 最外层一道Try Catch关,万无一失保证老板不会一个月之内出来骂你一次,最多只是偶尔来问下: 现在提示"系统繁忙,稍后再试",是怎么回事?

      

      

         

                                  

                  


             

       

  

  

我是谁