大家好,又见面了,我是你们的朋友全栈君。
1.构造函数不是方法!!
原因1:方法的话,会直接执行方法体内的代码,但是构造函数首先执行的不是{}里的代码块,而是给对象的成员初始化;
2.方法可以被调用其他方法调用,但是构造函数不能被方法或变量调用。
package com.statics.www; public class Son { //构造函数执行第二步: private int num2=1*cal2(); //构造函数执行第一步: public static int num1=1*cal1(); //构造函数第0步: public static int cal1(){ System.out.println(“构造函数第一步:静态变量赋值!”); return 1; } public static int cal2(){ System.out.println(“构造函数第二步:非静态全局变量赋值”); return 2; } { System.out.println(“构造函数第三步:代码块!”); } public Son(){ System.out.println(“构造函数第四步:执行构造函数内部代码块!”); }
}
执行结果为:
2. 从上面测试得出结论:
构造函数初始化对象时,执行的顺序是
0.方法优先存在于任何变量或者对象,存在于类中,而不是对象中。即构造对象前,方法就存在。
第一步. 静态变量赋值
第二步.代码块或者全局变量,(执行顺序由代码位置决定,如果代码块在前,优先执行代码块;如果变量在前,优先变量赋值)
第三步.执行构造函数内部代码
3.继承中的构造函数执行顺序:
0.子类重写了父类的方法;
1.调用父类构造函数();
2.调用子类构造函数();
父类代码:
package com.statics.www;
public class Father { private int num=1; public Father(){ System.out.println(“构造father,接下来调用Test()”); Test(); } public void Test(){ System.out.println(“调用Father被重写的方法Test(),现在的Num值是”+num); } } 子类代码:
package com.statics.www; public class Son extends Father { private int num=1; public Son(){ System.out.println(“执行Son构造函数内部代码块!”); } public void Test(){ System.out.println(“调用Son被重写的方法Test(),现在的Num值是”+num); } }
可以看出被调用的Test()方法是子类的Test(),另外特别注意Num =0!!!!!!因为父类的num 是private的不能继承,但是子类的num还没有被赋值(要等到父类构造完成,才能构造子类),所以默认是0
发布者:全栈程序员栈长,转载请注明出处:https://javaforall.cn/156916.html原文链接:https://javaforall.cn
扫码关注腾讯云开发者
领取腾讯云代金券
Copyright © 2013 - 2025 Tencent Cloud. All Rights Reserved. 腾讯云 版权所有
深圳市腾讯计算机系统有限公司 ICP备案/许可证号:粤B2-20090059 深公网安备号 44030502008569
腾讯云计算(北京)有限责任公司 京ICP证150476号 | 京ICP备11018762号 | 京公网安备号11010802020287
Copyright © 2013 - 2025 Tencent Cloud.
All Rights Reserved. 腾讯云 版权所有