Java对象创建详解:组合与继承中成员初始化顺序

需积分: 1 0 下载量 142 浏览量 更新于2024-09-10 收藏 48KB DOC 举报
Java对象的创建过程是一个涉及多个步骤的过程,特别是在组合和继承的情况下,成员初始化的顺序尤为重要。首先,当我们首次使用或访问一个类,如Dog类,Java解释器会查找类路径并加载对应的.class文件,如Dog.class,这时执行静态初始化,只在Class对象初次加载时进行。 创建Dog对象时,会在堆上为其分配内存,所有基本类型的成员会被自动初始化为默认值(如数值为0,布尔型和字符型为默认初始值),引用类型(如String)则设置为null。接下来,执行类中的域初始化动作,包括执行任何在构造器中定义的初始化代码。 在不涉及继承时,上述流程清晰明了。然而,当涉及到继承时,比如在`Mouse4j`示例中,有以下几个类: 1. `StaticField`类代表静态字段,其中有一个私有字段`Strings`。在构造函数中,它会初始化`Strings`并打印一条消息。 2. `NormalField`类表示具有普通字段的类,同样有一个私有字段`Strings`,构造函数中进行初始化。 3. `Characteristic`类继承自某个基类,包含一个私有字段`Strings`。在构造函数中,会先初始化`Strings`,再打印创建信息。 4. `Description`类可能是组合类,可能包含静态字段和普通字段,注释1指出如果组合类也有静态字段,那么这些静态字段会在类加载时初始化。 在组合情况下,确保子类的初始化顺序是正确的至关重要。首先,基类(包括静态字段)会被初始化,然后是子类的实例变量。如果子类有构造器,它们会在父类构造器之后执行。这意味着,如果`Description`类中有组合的`StaticField`,那么`StaticField`的静态初始化会在`Description`对象实例化之前完成。 总结起来,理解Java对象的创建过程,特别是处理组合和继承时,关键在于掌握构造器执行的时机、静态和非静态成员的初始化顺序。通过正确配置构造函数和遵循继承规则,可以确保程序按照预期的方式运行。

试着修改以下代码: (1) 定义变量m、k,通过输入的方式决定;定义N,假设为10;定义数组a,长度为N=10; (2) 随机生成一个0~9的数begin,作为报数开始的人的编号; (3) For循环从begin开始遍历,为a【begin】赋值为‘1’ (4) If判断:当前的值为‘null’,break跳出循环; (5) Else if:循环过程中指针所指的人的编号是否为从begin起的第m个,如果是,为a【begin+m-1】赋值‘null’; (6) Else:编号每后移一位,赋值在前一位的基础上+1; (7) 把begin+m-1赋给location,记录退出的人的编号;输出该编号; (8) 下一轮循环的开始从编号begin+m开始,循环结束的条件是:a【报数开始的人的编号+k+1】==a【报数开始的人的编号】 #include<stdio.h> #include<stdlib.h> #include<time.h> #define N 10 int main() { ​int m,k,begin,i,location,j; ​char a[N]; ​printf("please input the number which makes people exit:\n"); ​scanf("%d",&m); ​printf("please input the amount of people remained\n",k); ​scanf("%d",&k); ​ ​srand((unsigned int)time(NULL)); ​begin=rand()%10; ​for(j=begin;a[j+k+1]==a[j];j++) ​{ ​​​for(i=0;i<N;i++) ​​{ ​​​if(i!=begin) ​​​{ ​​​​break; ​​​} ​​​a[i]='1'; ​​ ​​​if(a[i]=='\0') ​​​{ ​​​​break; ​​​} ​​​else if(i==begin+m-1) ​​​{ ​​​​a[i]='\0'; ​​​​location=i; ​​​​printf("the number of the exit people is:%d\n",location); ​​​} ​​​else a[i]=a[i]+1; ​​ ​​​begin=begin+m; ​​} ​} ​ ​return 0; }

2023-05-10 上传
2023-05-31 上传