java – 为什么在超类的构造函数之后初始化成员对象?

昨天我遇到了一个有趣的问题,虽然修复非常简单,但我对它的“原因”仍然有点模糊.

我有一个类,它具有在实例化时分配的私有成员变量,但是如果它在超类的构造函数调用的抽象函数中使用,则该变量没有值.问题的解决方案非常简单,我只需将变量声明为静态并正确分配.一些代码来说明问题:

class Foo extends BaseClass
{
    private final String bar = "fooBar!";
    public Foo()
    {
        super();
    }

    @Override 
    public void initialize()
    {
        System.out.println(bar);
    }
}

和基类:

abstract class BaseClass
{
    public BaseClass()
    {
        initialize();
    }

    public abstract void initialize();
}

在这个例子中,当我们调用new Foo();它将输出(null)而不是预期的fooBar!

既然我们实例化了一个Foo类型的对象,它的成员是否应该在调用它(以及它的超类的)构造函数之前被分配和赋值?这是在Java语言中指定的,还是特定于JVM的?

感谢您的任何见解!

解决方法

bar =“fooBar!”的赋值;在编译期间内联到构造函数中.

超类构造函数运行before子类构造函数,因此事后执行该语句是很自然的.

但一般来说,从构造函数调用可覆盖的方法bad practice.

相关文章

ArrayList简介:ArrayList 的底层是数组队列,相当于动态数组。与 Java 中的数组相比,它的容量能动态增...
一、进程与线程 进程:是代码在数据集合上的一次运行活动,是系统进行资源分配和调度的基本单位。 线程...
本文为博客园作者所写: 一寸HUI,个人博客地址:https://www.cnblogs.com/zsql/ 简单的一个类...
#############java面向对象详解#############1、面向对象基本概念2、类与对象3、类和对象的定义格式4、...
一、什么是异常? 异常就是有异于常态,和正常情况不一样,有错误出错。在java中,阻止当前方法或作用域...
Collection接口 Collection接口 Collection接口 Collection是最基本的集合接口,一个Collection代表一组...