请问为什么super调用父类构造器,父类构造器中调用的方法会是子类中重写的方法?


public class A {
  public A(){
      doSome();  
  }
  public void doSome(){}
}

public class B extends A {
  private final int a;
  public B(int a){
      this.a = a;
  }
  @Override
  public void doSome(){
      System.out.println(a);
  }
  public static void main(String[] args){
    B b = new B();
    b.doSome();
  }
}

就比如上边这段代码,B类继承了A类,然后我创建一个B的实例,在B的构造器中首先会去调A的构造器,然后A中调用了doSome方法。我原本以为会去调A类的doSome,也就是什么也不输出。但是打印之后输出了一个0,调用的是B类覆盖的doSome。请问这是为什么呢?为什么A类的构造器中会调用B类覆盖的方法?难道不是调用A类自己的方法吗?

你实例化B类又调用B类的方法