通过查找Java的API发现:抽象类有构造方法,而接口没有构造方法。 抽象类不可以直接创建对象,表示抽象类本身不能被实例化,即 抽象类 a = new 抽象类();这样写是错误的,但是抽象类可以声明对象,因为,抽象类的子类必须复写抽象类中的所有抽象方法,即抽象类的子类是可以直接实例化的,所以,通过父类的引用来指向子类的实例来间接地实现父类的实例化,这是父类引用指向子类对象的多态机制的体现。
比如:public abstract class Toolkit extends Object ,Toolkit 是抽象类,不能直接通过new创建对象,但是 这个抽象类Toolkit 有构造方法 public Toolkit() ,它提供静态
public static Toolkit getDefaultToolkit()给Toolkit创建对象,即有很方法会返回抽象类Toolkit 的实例,像public static Toolkit getDefaultToolkit()返回默认工具包。抽象类是无法通过 new 关键字创建对象的,但是这里为什么会返回抽象类抽象类的应用呢?抽象类的实例
是怎么创建的呢?Toolkit i = Toolkit.getDefaultToolkit(); 这句话并没有实例化抽象类Toolkit ,Toolkit i 只是声明一个类型为Toolkit 的变量 i , Toolkit.getDefaultToolkit(); 是获取抽象
类 Toolkit 的一个实例对象。从Toolkit.getDefaultToolkit(); 中所获得的实例其实就是一个Toolkit 的子类的对象,它实现了Toolkit 里面的抽象方法。
使用Toolkit.getDefaultToolkit(); 的好处:
1、new一定要生成一个新对象,分配内存;Toolkit.getDefaultToolkit(); 则不一定要再次创建,它可以把一个已存在的引用给你使用,这在效能上优于new;
2、new创建后只能当次使用,而Toolkit.getDefaultToolkit(); 可以跨栈区域使用,或者远程跨区域使用。所以Toolkit.getDefaultToolkit(); 通常是创建static静态实例方法的。
抽象类其实是可以实例化的,但是它的实例化方式不是通过new方式来创建对象,而是通过父类的引用来指向子类的实例来间接地实现父类的实例化(因为子类要实例化前,一定会先实例化他的父类。这样创建了继承抽象类的子类的对象,也就把其父类(抽象类)给实例化了),但是,接口是不能被实例化的(接口压根就没有构造函数)
public class CC {
public static void main(String[] args) {
A a = new B();
a.my1();
a.my();
System.out.println(a.i);
System.out.println(((B) a).i);
}
}
abstract class A {
int i = 0;
public void my() {
System.out.println("A my");
}
abstract void my1();
}
class B extends A {
int i = 1;
public void my1() {
System.out.println("B A my1");
}
}
运行结果为: