时间:2021-05-19
对于这个问题应该用JVM的工作步骤来解释,首先看如下代码
class X { Y b = new Y(); X() { System.out.print("X"); } } class Y { Y() { System.out.print("Y"); } } public class Z extends X { Y y = new Y(); Z() { System.out.print("Z"); } public static void main(String[] args) { new Z(); //结果是 YXYZ } }这段代码的执行过程如下:
1.在栈内存定义变量此时为初始值,定义方法。基本数据类型为0 ,引用数据类型为null
2. 调用父类构造方法,定义父类的属性和方法(如果子类已经重写父类的方法 这时不会被覆盖,整个过程不会发生任何覆盖的情 况)
3. 给父类的变量赋值。(此处即new了一个Y对象)
4. 执行父类构造方法中其他语句(此时它自己变量已经初始化和赋值完成,貌似很合理)
5. 给自己变量赋值(在堆内存创建对象或常量)(此处也是new了一个Y对象)
6. 执行构造方法中其他语句
铺垫的小知识:
第一个:成员变量有基本类型和引用类型的。
class Demo { //基本类型 int x = 10; //引用类型 Student s = new Student(); }第二个:类的初始化过程
加载class文件
堆中开辟空间
变量的默认初始化
变量的显示初始化
构造代码块初始化
构造方法初始化
第三个:遇到extends,就要知道,先初始化父类数据,然后初始化子类数据。
分层初始化。
super在这里仅仅表示要先初始化父类数据。
补充知识:Java 设计一个Dog类,有名字、颜色、年龄等属性,定义构造方法来初始化类的这些属性,定义方法输出Dog信息。编写应用程序使用Dog类。
我就废话不多说了,大家还是直接看代码吧~
class Dog{ private String name,color; private int age; public Dog(String name,String color,int age){ this.name=name; this.color=color; this.age=age; } public void print(){ System.out.println("名字:"+name+" 颜色:"+color+" 年龄:"+age+"岁"); }}public class DogTest{ public static void main(String args[]){ Dog d=new Dog("哈士奇","白色",5); d.print(); }}以上这篇聊聊Java 成员变量赋值和构造方法谁先执行的问题就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持。
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
前言当我们面对具有大量可选成员变量的Java类时,创建这些对象的最佳方法是什么?通常有三种方法:伸缩构造函数,JavaBean模式和构建器模式。构造函数User
之前看一些资料提到浅拷贝的问题,即在复制对象时,只是对对象中的数据成员进行简单的赋值,默认拷贝构造函数执行的也是浅拷贝。如果对象中存在动态成员,如指针,那么仅仅
构造方法用来初始化类的对象,与父类的其它成员不同,它不能被子类继承(子类可以继承父类所有的成员变量和成员方法,但不继承父类的构造方法)。因此,在创建子类对象时,
创建类的一个实例时,在执行构造函数之前,如果你没有给成员变量赋初始值,C#编译器缺省将每一个成员变量初始化为他的默认值。如果变量是方法的局部变量,编译器就会认为
总结:1.常量数据成员,形式:constTypem_tData;1)常量数据成员,需要在构造函数列表中给出,构造函数中可以用常量赋值,也可以实例化的时候赋值。2