举例:
package com.md.test;
/**
* 父子类的代码块,方法,构造函数执行顺序
* */
public class Test02 {
static{
System.out.println("public类的static 代码块。");
j = 10;
}
private static int j;
public static void main(String[] args) {
System.out.println("====父类A====");
new A();
System.out.println(new A());
System.out.println("=====子类B=====");
new B();
System.out.println("=====父类A=====");
new A();
}
}
class A{
public A(){
System.out.println("我是父类的无参构造");
}
{
System.out.println("我是父类的构造代码块");
int i = 10;
}
static {
System.out.println("我是父类的静态代码块");
}
public void qaq(){
System.out.println("我是父类的普通方法");
}
}
class B extends A{
public B(){
System.out.println("我是子类的无参构造");
}
{
System.out.println("我是子类的构造代码块");
}
static {
System.out.println("我是子类的静态代码块");
}
}
Console:
"C:\Program Files\Java\jdk1.8.0_301\bin\java.exe" "-javaagent:D:\下载\电脑应用\IntelliJ IDEA 2021.2.1\lib\idea_rt.jar=64685:D:\下载\电脑应用\IntelliJ IDEA 2021.2.1\bin" -Dfile.encoding=UTF-8 -classpath "C:\Program Files\Java\jdk1.8.0_301\jre\lib\charsets.jar;C:\Program Files\Java\jdk1.8.0_301\jre\lib\deploy.jar;C:\Program Files\Java\jdk1.8.0_301\jre\lib\ext\access-bridge-64.jar;C:\Program Files\Java\jdk1.8.0_301\jre\lib\ext\cldrdata.jar;C:\Program Files\Java\jdk1.8.0_301\jre\lib\ext\dnsns.jar;C:\Program Files\Java\jdk1.8.0_301\jre\lib\ext\jaccess.jar;C:\Program Files\Java\jdk1.8.0_301\jre\lib\ext\jfxrt.jar;C:\Program Files\Java\jdk1.8.0_301\jre\lib\ext\localedata.jar;C:\Program Files\Java\jdk1.8.0_301\jre\lib\ext\nashorn.jar;C:\Program Files\Java\jdk1.8.0_301\jre\lib\ext\sunec.jar;C:\Program Files\Java\jdk1.8.0_301\jre\lib\ext\sunjce_provider.jar;C:\Program Files\Java\jdk1.8.0_301\jre\lib\ext\sunmscapi.jar;C:\Program Files\Java\jdk1.8.0_301\jre\lib\ext\sunpkcs11.jar;C:\Program Files\Java\jdk1.8.0_301\jre\lib\ext\zipfs.jar;C:\Program Files\Java\jdk1.8.0_301\jre\lib\javaws.jar;C:\Program Files\Java\jdk1.8.0_301\jre\lib\jce.jar;C:\Program Files\Java\jdk1.8.0_301\jre\lib\jfr.jar;C:\Program Files\Java\jdk1.8.0_301\jre\lib\jfxswt.jar;C:\Program Files\Java\jdk1.8.0_301\jre\lib\jsse.jar;C:\Program Files\Java\jdk1.8.0_301\jre\lib\management-agent.jar;C:\Program Files\Java\jdk1.8.0_301\jre\lib\plugin.jar;C:\Program Files\Java\jdk1.8.0_301\jre\lib\resources.jar;C:\Program Files\Java\jdk1.8.0_301\jre\lib\rt.jar;E:\IDEA\Study every Day\Day03\target\classes;E:\apache-maven-3.8.1-bin\Study\org\springframework\boot\spring-boot-starter\2.4.1\spring-boot-starter-2.4.1.jar;E:\apache-maven-3.8.1-bin\Study\org\springframework\boot\spring-boot\2.4.1\spring-boot-2.4.1.jar;E:\apache-maven-3.8.1-bin\Study\org\springframework\spring-context\5.3.2\spring-context-5.3.2.jar;E:\apache-maven-3.8.1-bin\Study\org\springframework\spring-aop\5.3.2\spring-aop-5.3.2.jar;E:\apache-maven-3.8.1-bin\Study\org\springframework\spring-beans\5.3.2\spring-beans-5.3.2.jar;E:\apache-maven-3.8.1-bin\Study\org\springframework\spring-expression\5.3.2\spring-expression-5.3.2.jar;E:\apache-maven-3.8.1-bin\Study\org\springframework\boot\spring-boot-autoconfigure\2.4.1\spring-boot-autoconfigure-2.4.1.jar;E:\apache-maven-3.8.1-bin\Study\org\springframework\boot\spring-boot-starter-logging\2.4.1\spring-boot-starter-logging-2.4.1.jar;E:\apache-maven-3.8.1-bin\Study\ch\qos\logback\logback-classic\1.2.3\logback-classic-1.2.3.jar;E:\apache-maven-3.8.1-bin\Study\ch\qos\logback\logback-core\1.2.3\logback-core-1.2.3.jar;E:\apache-maven-3.8.1-bin\Study\org\apache\logging\log4j\log4j-to-slf4j\2.13.3\log4j-to-slf4j-2.13.3.jar;E:\apache-maven-3.8.1-bin\Study\org\apache\logging\log4j\log4j-api\2.13.3\log4j-api-2.13.3.jar;E:\apache-maven-3.8.1-bin\Study\org\slf4j\jul-to-slf4j\1.7.30\jul-to-slf4j-1.7.30.jar;E:\apache-maven-3.8.1-bin\Study\jakarta\annotation\jakarta.annotation-api\1.3.5\jakarta.annotation-api-1.3.5.jar;E:\apache-maven-3.8.1-bin\Study\org\springframework\spring-core\5.3.2\spring-core-5.3.2.jar;E:\apache-maven-3.8.1-bin\Study\org\springframework\spring-jcl\5.3.2\spring-jcl-5.3.2.jar;E:\apache-maven-3.8.1-bin\Study\org\yaml\snakeyaml\1.27\snakeyaml-1.27.jar;E:\apache-maven-3.8.1-bin\Study\org\slf4j\slf4j-api\1.7.30\slf4j-api-1.7.30.jar" com.md.test.Test02
public类的static 代码块。
====父类A====
我是父类的静态代码块
我是父类的构造代码块
我是父类的无参构造
=====子类B=====
我是子类的静态代码块
我是父类的构造代码块
我是父类的无参构造
我是子类的构造代码块
我是子类的无参构造
=====父类A=====
我是父类的构造代码块
我是父类的无参构造
Process finished with exit code 0
总结:静态资源>代码块>构造函数>普通方法。 子类继承父类后,调用子类会先执行子类继承父类的功能,然后才会执行子类自己的功能。