java继承执行顺序_Java 继承 执行顺序

代码:

packagecom.company;public classMain {public static voidmain(String[] args) {newMyClass();

}

}classTest {

Person person= new Person("Test");static{

System.out.println("test static");

}publicTest() {

System.out.println("test constructor");

}

}classPerson{static{

System.out.println("person static");

}publicPerson(String str) {

System.out.println("person "+str);

}

}class MyClass extendsTest {

Person person= new Person("MyClass");static{

System.out.println("myclass static");

}publicMyClass() {

System.out.println("myclass constructor");

}

}

结果:

test staticmyclassstaticpersonstaticperson Test

test constructor

person MyClass

myclass constructor

========================================================

默认构造函数与有参数构造函数

代码:

public classMain {public static voidmain(String[] args) {new Child("mike");

}

}classPeople {

String name;publicPeople() {

System.out.print(1);

}publicPeople(String name) {

System.out.print(2);this.name =name;

}

}class Child extendsPeople {

People father;publicChild(String name) {//super(name);

System.out.print(3);this.name =name;

father= new People(name + ":F");

}publicChild() {

System.out.print(4);

}

}

结果:

8f900a89c6347c561fdf2122f13be562.png

961ddebeb323a10fe0623af514929fc1.png

132

View Code

考察的又是父类与子类的构造函数调用次序。在Java中,子类的构造过程中必须调用其父类的构造函数,是因为有继承关系存在时,子类要把父类的内容继承下来。但如果父类有多个构造函数时,该如何选择调用呢?

第一个规则:子类的构造过程中,必须调用其父类的构造方法。一个类,如果我们不写构造方法,那么编译器会帮我们加上一个默认的构造方法(就是没有参数的构造方法),但是如果你自己写了构造方法,那么编译器就不会给你添加了,所以有时候当你new一个子类对象的时候,肯定调用了子类的构造方法,但是如果在子类构造方法中我们并没有显示的调用基类的构造方法,如:super();  这样就会调用父类没有参数的构造方法。

第二个规则:如果子类的构造方法中既没有显示的调用基类构造方法,而基类中又没有无参的构造方法,则编译出错,所以,通常我们需要显示的:super(参数列表),来调用父类有参数的构造函数,此时无参的构造函数就不会被调用。

总之,一句话:子类没有显示调用父类构造函数,不管子类构造函数是否带参数都默认调用父类无参的构造函数,若父类没有则编译出错。

如果取消注释中的代码,那么结果就是232

==========================================================================================

代码:

public classMain {public static voidmain(String[] args) {newDervied();

}

}class Dervied extendsBase {private String name = "dervied";publicDervied() {

tellName();

printName();

}public voidtellName() {

System.out.println("Dervied tell name: " +name);

}public voidprintName() {

System.out.println("Dervied print name: " +name);

}

}classBase {private String name = "base";publicBase() {

tellName();

printName();

}public voidtellName() {

System.out.println("Base tell name: " +name);

}public voidprintName() {

System.out.println("Base print name: " +name);

}

}

结果:

8f900a89c6347c561fdf2122f13be562.png

961ddebeb323a10fe0623af514929fc1.png

Dervied tell name: nullDervied print name:nullDervied tell name: dervied

Dervied print name: dervied

View Code

原因:

1、首先private是不会继承到新的对象里,所以不会出现“base”。

2、由于重写的缘故,在执行super的构造函数是,还是调用的子类方法,此时成员变量未初始化。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值