java加载父类_Java中接口,父类,子类的加载顺序的一点总结

先写了四个类,很简单的类:目标是测试类的静态变量初始化,静态代码调用,成员变量初始化,构造函数调用的先后顺序。

// 辅助输出类

public class Print {

public Print(String str) {

System.out.println(str);

}

}

// 接口类

public interface InterfaceDemo {

Object so1 = new Print("接口静态变量初始化");

}

// 父类

public class SuperDemo {

static Object so2 = new Print("父类静态变量初始化");

Object o2 = new Print("父类非静态变量初始化");

static {

new Print("父类静态代码块被调用");

}

public SuperDemo() {

new Print("父类构造函数被调用");

}

}

// 子类

public class SubDemo extends SuperDemo implements InterfaceDemo {

static Object so3 = new Print("子类静态变量初始化");

Object o3 = new Print("子类非静态变量初始化");

static {

new Print("子类静态代码块被调用");

}

public SubDemo() {

new Print("子类构造函数被调用");

}

public static void main(String[] args) {

SubDemo o;

new Print("上面声明一个子类的引用,下面创建一个子类对象");

o = new SubDemo();

Object oo = o.so1;

}

}

直接执行子类中的main方法,输出结果如下:

父类静态变量初始化

父类静态代码块被调用

子类静态变量初始化

子类静态代码块被调用

上面声明一个子类的引用,下面创建一个子类对象

父类非静态变量初始化

父类构造函数被调用

子类非静态变量初始化

子类构造函数被调用

接口静态变量初始化

应该说,大部分都按照设想的顺序执行的,除了接口中的变量用到时才初始化是没有想到的。之所以写这么个测试是因为在编程时碰到一个这么一个问题,再创建子类对象时总是提示空指针异常。究其原因就是因为当代码执行到父类构造函数时,子类对象的成员就是还没有被初始化,可恰恰此时父类构造函数调用了一被子类重写的方法,这个方法企图操作子类的还没有初始化的变量。

为什么会出现这个意外呢?因为写子类时企图让子类的一个特定成员变量跟随父类的成员变量变化而变化(这种需求应该来说也算正常),然后有可能父类的成员变量变化时子类成员变量还没初始化。怎么解决这个问题,关键有两点:(1)在子类重写的函数中,操作子类特定成员变量时要先测试是否已经初始化;(2)要在子类构造函数中设定需要同步的成员变量的值。当然如果可能的话,也可以修改父类的构造函数代码,让其不在调用重写过的方法也算是一种的简单方法。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值