C++和Java 的缺省初始化问题
缺省初始化这是个基础问题,但往往有些迷惑,尤其是当你同一个时间有时写Java,有时写C++ ,总结如下:
C++中基本类型只有作为全局变量才会进行,而对于类类型只要这个类具有一个无参构造函数则不管这个类的对象是局部变量还是全局变量,它都会进行缺省的初始化,甚至当一个对象通过缺省初始化机制进行创建时,这个对象的类类型数据成员也会根据它们自己的无参构造函数进行缺省的初始化。
但是若该类没有无参构造函数,那么若这个类没有任何构造函数,系统将会为这个类提供一个缺省的无参构造函数,理论上这个构造函数会讲这个类的每个数据成员初始化为释放类型的0,但是这因编译器而异,我们最好不要有依赖,系统提供的缺省无参构造函数完全有可能只进行内存分配而不进行初始化;
若还有其他构造函数,则系统不会提供无参构造函数,此时编译器编译不通过,对于这种情况在实际编程中我们可以对其他构造函数之一的所有参数进行缺省赋值来弥补。
系统不会提供无参构造函数的另外一个情况是:一个类包含了未初始化的const或引用成员,在这种情况下,我们别无选择,职能显式的进行初始化。注意,此时不能在类的内部进行初始化,其实在C++中未有static const类型的数据成员可以进行类内部初始化,除此以外数据成员都不能在类内部进行初始化,但Java并没有这些限制。
对于这个问题,Java就有一个准则,那就是当一个变量被定义时(而不是只声明不定义--当然,这种情况只有一个:变量在一个函数内部初次出现,且没有提供初始值时),它总是缺省的初始化为适当类型的0(除非这个变量已经在类定义中有初始值了——再次注意这个在C++中是不可行的)。但和C++不同,Java的一个对象中类类型数据成员的引用不会使用无参构造函数进行缺省的初始化,而是简单的置为null。
最后,要注意的是Java不允许我们为一个函数的参数提供缺省值,因为我们再C++中通过给一个常规的构造函数参数提供缺省值来达到无参构造函数的方法在Java中无法使用。
对于数组,C++的缺省初始化规则如下:
基本类型的数组,若为全局作用域则被缺省初始化为适当类型的0,若为局部作用域则不会被缺省初始化。