原文
在代码中我们经常能看到下面这样的语句。
A a = new A();(1) B b = null;(2) C c;(3)
代码( 1 )
创建 A 的对象并对其进行初始化。
A :类;
new A() :创建 A 的对象并对其初始化;
a :引用,指向 new A() 这个对象的引用。
注意: a 不是 A 的对象, new A() 才是 A 的对象。
代码( 2 )
声明 引用 b ,并指向 null 。
B :类;
b :引用,指向的对象为 null (空)。
代码( 3 )
与代码( 2 )一样,声明一个 引用 。
与代码( 2 )的区别是:代码( 3 )中 声明 的引用 c 不指向任何对象。
提示:变量本质上是引用的一个别名而已 。
由上面的分析可以了解到,在 C# 中实例化一个对象时,需要经历下面这几步:
- 声明引用;
- 使用 new 关键字创建类的对象并对其初始化;(分配内存空间)
- 将引用指向类的对象。
若没有使用 new关键字 创建类的实例,则仅仅创建引用,指向的对象为 null 。
实例说明
public class ExampleModel { public int C1 { get; set; } public string C2 { get; set; } } ExampleModel e1 = new ExampleModel(); ExampleModel e2 = null; ExampleModel e3; if (e1 == null) { Console.WriteLine("e1 == null"); } else { Console.WriteLine("{ C1 = " + e1.C1 + ", C2 = " + e1.C2 + " }"); } if (e2 == null) { Console.WriteLine("e2 == null"); } else { Console.WriteLine("{ C1 = " + e2.C1 + ", C2 = " + e2.C2 + " }"); } if (e3 == null) { Console.WriteLine("e3 == null"); } else { Console.WriteLine("{ C1 = " + e3.C1 + ", C2 = " + e3.C2 + " }"); }编译代码,会出现编译错误,提示“使用了未赋值的局部变量 e3 ”,原因是并未对 e3进行初始化,但是使用 e2 变量时并不会产生编译错误,因为 e2 已经被初始化了,只是初始化的值为 null 而已,这并不影响编译的通过。
注释掉e3 部分的代码,运行程序得到下图所示的结果。
在开发过程中,我们还是尽量不要让一个引用指向 null ,否则在运行过程中很容易出现空引用的异常。
修改 e2 部分的代码, 去掉e2是否为空引用的条件判断, 并运行程序。
运行中,会产生“未将对象引用设置到对象的实例。”的异常。(原因你懂的。)
同样去掉 e1 部分中是否为空引用的条件判断语句,再次执行程序,一切正常。(因为e1指向了不为null的对象)