C++和Java的缺省初始化问题

  缺省初始化这是个基础问题,但往往有些迷惑,尤其是当你同一个时间有时写Java,有时写C++ ,总结如下:

  C++中基本类型只有作为全局变量才会进行,而对于类类型只要这个类具有一个无参构造函数则不管这个类的对象是局部变量还是全局变量,它都会进行缺省的初始化,甚至当一个对象通过缺省初始化机制进行创建时,这个对象的类类型数据成员也会根据它们自己的无参构造函数进行缺省的初始化。

  但是若该类没有无参构造函数,那么若这个类没有任何构造函数,系统将会为这个类提供一个缺省的无参构造函数,理论上这个构造函数会讲这个类的每个数据成员初始化为释放类型的0,但是这因编译器而异,我们最好不要有依赖,系统提供的缺省无参构造函数完全有可能只进行内存分配而不进行初始化;

  若还有其他构造函数,则系统不会提供无参构造函数,此时编译器编译不通过,对于这种情况在实际编程中我们可以对其他构造函数之一的所有参数进行缺省赋值来弥补。

  系统不会提供无参构造函数的另外一个情况是:一个类包含了未初始化的const或引用成员,在这种情况下,我们别无选择,职能显式的进行初始化。注意,此时不能在类的内部进行初始化,其实在C++中未有static const类型的数据成员可以进行类内部初始化,除此以外数据成员都不能在类内部进行初始化,但Java并没有这些限制。

  对于这个问题,Java就有一个准则,那就是当一个变量被定义时(而不是只声明不定义--当然,这种情况只有一个:变量在一个函数内部初次出现,且没有提供初始值时),它总是缺省的初始化为适当类型的0(除非这个变量已经在类定义中有初始值了--再次注意这个在C++中是不可行的)。但和C++不同,Java的一个对象中类类型数据成员的引用不会使用无参构造函数进行缺省的初始化,而是简单的置为null.

  最后,要注意的是Java不允许我们为一个函数的参数提供缺省值,因为我们再C++中通过给一个常规的构造函数参数提供缺省值来达到无参构造函数的方法在Java中无法使用。

  对于数组,C++的缺省初始化规则如下:

  基本类型的数组,若为全局作用域则被缺省初始化为适当类型的0,若为局部作用域则不会被缺省初始化。

  类类型的数组,若作为数组元素的类没有一个无参构造函数(此时定义了一个或多个其他的构造函数,系统因此也不会提供缺省无参构造函数了),则该数组无法声明;若有一个程序员显式提供的无参构造函数则会进行初始化;若有一个系统提供的隐式无参缺省初始化构造函数则在全局作用域上才会初始化。

  而在Java中C++的数组初始化问题是不存在的,数组的各个元素都会自动进行初始化,类类型对象的数组元素将初始化为null.

时间: 2024-09-19 09:02:26

C++和Java的缺省初始化问题的相关文章

java代码-Java编程中的初始化问题

问题描述 Java编程中的初始化问题 为啥初始化字符串数组要放在无参构造函数中?放在外面时,就会报数组越界异常?代码如下: import java.sql.Connection; import java.sql.DriverManager; import java.sql.PreparedStatement; import java.util.HashMap; import java.util.Map; import com.bdqn.hibernate.model.Student; publi

图文详解Java中class的初始化顺序_java

class的装载 在讲class的初始化之前,我们来讲解下class的装载顺序. 以下摘自<Thinking in Java 4> 由于Java 中的一切东西都是对象,所以许多活动 变得更加简单,这个问题便是其中的一例.正如下一章会讲到的那样,每个对象的代码都存在于独立的文件中.除非真的需要代码,否则那个文件是不会载入的.通常,我们可认为除非那个类的一个对象构造完毕,否则代码不会真的载入.由于static 方法存在一些细微的歧义,所以也能认为"类代码在首次使用的时候载入".

解析Java虚拟机中类的初始化及加载器的父委托机制_java

类的初始化 在初始化阶段,Java虚拟机执行类的初始化语句,为类的静态变量赋予初始值. 在程序中,静态变量的初始化有两种途径: 1.在静态变量的声明处进行初始化: 2.在静态代码块中进行初始化. 没有经过显式初始化的静态变量将原有的值.   一个比较奇怪的例子: package com.mengdd.classloader; class Singleton { // private static Singleton mInstance = new Singleton();// 位置1 // 位置

Java数组一定要初始化才能使用吗?

数组是大多数编程语言提供的一种复合结构,如果程序需要多个类型相同的变量时,就可以考虑定义一个数组.Java语言的数组变量是引用类型的变量,因此具有Java独有的特性. 在正常的Java开发中,使用Java数组之前,我们都会对数组进行初始化,为数组中的元素分配内存空间.赋值等,但Java数组一定要初始化吗?不初始化可以 么? 其实,java的数组变量是引用类型的变量,并不是数组对象本身,只要让数组变量指向有效的数组对象,程序中就可使用该数组变量,比如下面这个例子: public class T {

java static 静态变量初始化

java static 静态变量初始化 static final int NUMBER_OF_MONTHS = 12; static final float PI = (float) 22 / 7; 如果你想使一个静态变量在其它地方可以引用的话,如下 public static final int NUMBER_OF_MONTHS = 12; public static final float PI = (float) 22 / 7; 写在函数中 public class MainClass {

Java 重写方法与初始化的隐患

虽然文章标题是Java, 但几乎所有面向对象设计的语言都遵守这个初始化流程, 感谢廖祜秋liaohuqiu_秋百万指出, 之前忘记提这个了. 前言 drakeet写了个和RecyclerView相关的GenerousRecyclerView, 原文提到了写这个的目的. 因为需要知道ViewGroup的clipToPadding属性, 所以调用了ViewGroup.getClipToPadding, 但这个方法是API level 21引入的. 我看了一下代码, ViewGroup是通过调用set

Java重写方法与初始化的隐患(转)

原文出处: Shawon 虽然文章标题是Java, 但几乎所有面向对象设计的语言都遵守这个初始化流程, 感谢廖祜秋liaohuqiu_秋百万指出, 之前忘记提这个了. 前言 drakeet写了个和RecyclerView相关的GenerousRecyclerView, 原文提到了写这个的目的. 因为需要知道ViewGroup的clipToPadding属性, 所以调用了ViewGroup.getClipToPadding, 但这个方法是API level 21引入的. 我看了一下代码, View

java中创建并初始化字符串方法

1.使用字符串常量直接初始化 String s="hello!"; 2.使用构造方法创建并初始化 String();//初始化一个对象,表示空字符序列 String(value);//利用已存在的字符串常量创建一个新的对象 String (char[] value);//利用一个字符数组创建一个字符串 String(char[] value,int offset,int count);//截取字符数组offset到count的字符创建一个非空串 String(StringBuffer

java 赋值运算符、拷贝初始化和this指针

  1)首先区别什么是赋值,什么是初始化. 2)程序中重载采用了引用传递,原因:①众所周知,用值传递的参数将在要传递的函数内产生一个副本,没有例外.如果这个对象很大,则副本就会浪费汗多空间.②在某些情况下可能想记录对象的数目.如果编译器在使用赋值运算符时,每次产生一个额外的对象,这样就可能见到比医疗多得多的对象.而引用传递有助于避免创建过多的对象. 3)return alpha(data); 返回值是重载函数所在的对象的一个副本,而不是同一个对象.返回的值可使它将运算符=串联起来:a3=a2=a