Java 抽象方法实例化

通过查找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");
}
}

  


运行结果为:


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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值