不能。抽象类不能被实例化,故其方法无法直接调用;但子类继承后可通过子类实例调用父类非抽象方法,抽象方法则需子类实现且在多态上下文中调用。

抽象类的方法能直接调用吗?
不能。抽象类本身不能被 new 实例化,所以无法直接调用其任何方法(包括非抽象方法)。但抽象类中定义的 public 或 protected 非抽象方法,只要子类继承并可访问,就一定能通过子类实例调用——这是多态的基础前提。
为什么子类实例能调用抽象父类的非抽象方法?
因为 Java 的继承机制会把父类(含抽象类)中所有可访问的非抽象方法“复制”到子类的运行时方法表里。只要子类没重写,调用的就是父类原始实现;如果重写了,运行时根据实际类型动态绑定(即动态分派)。
abstract class Animal { void breathe() { System.out.println("breathing"); } }class Dog extends Animal {}Dog d = new Dog(); d.breathe(); // 输出 breathing,调用的是 Animal 中的实现
抽象方法调用时要注意什么?
抽象方法没有实现,只能由子类提供具体逻辑。调用它必须满足两个条件:子类已实现该方法,且调用发生在多态上下文中(即变量声明为抽象类型,实际指向子类实例)。
- 错误写法:
Animal a = new Animal(); a.eat();→ 编译报错:Animal is abstract; cannot be instantiated - 正确写法:
Animal a = new Dog(); a.eat();→ 假设Dog重写了eat(),此时调用的是Dog.eat() - 若子类没实现抽象方法,编译直接失败:
Dog必须声明为abstract或实现全部抽象方法
多态调用时,方法解析顺序是怎样的?
Java 在运行时按「实际对象类型 → 直接父类 → 祖先类」向上查找第一个匹配的非抽象实现。静态方法、私有方法、构造器不参与多态;final 方法虽可被继承但不可重写,因此也总是绑定到声明它的类。
立即学习“Java免费学习笔记(深入)”;
- 假设
Animal有void move(),Dog重写了它,Poodle又继承Dog但没重写move() -
Animal a = new Poodle(); a.move();→ 实际执行的是Dog.move() - 如果
Animal.move()是private或static,则a.move()调用的是Animal自己的版本,与实际类型无关
protected 方法在子类外也能通过子类实例调用,其实访问权限依然受限。









