java的Toolkit的子类,Java 抽象方法实例化

本文探讨了Java中抽象类与接口的区别,抽象类虽然有构造方法但不能直接实例化,可以通过子类对象间接实现。接口则完全不能被实例化。以`Toolkit`类为例,说明了如何通过静态工厂方法获取抽象类的实例,这种方式在性能和跨区域使用上有优势。同时,展示了如何通过父类引用指向子类对象实现多态。代码示例展示了抽象类`A`和子类`B`的实例化过程,并解释了运行结果。
摘要由CSDN通过智能技术生成

通过查找Java的API发现:抽象类有构造方法,而接口没有构造方法。 抽象类不可以直接创建对象,表示抽象类本身不能被实例化,即 抽象类 a = new 抽象类();这样写是错误的,但是抽象类可以声明对象,因为,抽象类的子类必须复写抽象类中的所有抽象方法,即抽象类的子类是可以直接实例化的,所以,通过父类的引用来指向子类的实例来间接地实现父类的实例化,这是父类引用指向子类对象的多态机制的体现。

比如:public abstract classToolkit extendsObject ,Toolkit 是抽象类,不能直接通过new创建对象,但是 这个抽象类Toolkit 有构造方法 publicToolkit() ,它提供静态

public static Toolkit getDefaultToolkit()给Toolkit创建对象,即有很方法会返回抽象类Toolkit 的实例,像public staticToolkitgetDefaultToolkit()返回默认工具包。抽象类是无法通过 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");

}

}

运行结果为:

229163.html

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值