java继承的初始化机制

Java类在加载时会按顺序初始化static代码块和静态变量。static方法仅加载引用,实际调用时才会执行。在继承场景下,初始化顺序为:父类静态代码块->子类静态代码块->父类静态变量->子类静态变量->父类实例化对象->子类实例化对象->父类构造方法->子类构造方法。引用只能调用父类中定义的方法,而实际调用时会根据实例类型确定执行哪个方法。子类实例会先调用自身的方法,再调用父类方法。
摘要由CSDN通过智能技术生成

加载类的初始化过程

1 static属于类的变量,static方法属于类方法,他们都通过类名.方法/属性进行调用。在JVM加载类时,首先会从下到下加载类的static代码块或static变量(它们是按照上下顺序加载的)。对于static方法也加载了,但是没有具体的实现。我的理解就是:static方法的加载和其他的方法加载都会在类被JVM加载的,但是只是加载了一个引用(这里不是类的引用而是方法的引用,就好像接口声明了一个方法差不多),并没有具体的实现,当通过类名+static方法的时候,static方法才会被真正的加载,普通方法在new class()+方法调用的时候才会被真正的初始化。
调用顺序如果有继承的话:父类的静态代码块->子类的静态代码块->父类的静态变量->子类的静态变量->父类的普通初始化对象->子类的普通初始化对象->父类构造方法->子类构造方法!

代码Father父类!

package com.demo.ex.demo;

/**
 * 子类继承父类的加载过程
 * 
 * @author dan.wang
 *
 */
public class Father {
   
    static ExternalConfig ec = new ExternalConfig("father's static param");
    @SuppressWarnings("unused")
    private String name;
    @SuppressWarnings("unused")
    private String age;

    static {
        System.out.println("Father's static field");
    }

    public Father() {
        System.out.println("Faher constructure");
        // display();
    }

    ExternalConfig ecc = new ExternalConfig("father' param no static");

    public Father(String name, String age) {
        this.name = name;
        this.age = age;
        System.out.println("Faher two params constructure");
    }

    public static void fatherSMA() {
        System.out.println(
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值