onions 2007-5-15 09:54
详细解析Java中抽象类和接口的区别
[font=Courier New]在[/font]Java语言中, [font=Courier New]abstract class [/font]和[font=Courier New]interface[/font] 是支持抽象类定义的两种机制。正是由于这两种机制的存在,才赋予了Java强大的 面向对象能力。/F[,qo?{\
[font=Courier New]abstract class[/font]和[font=Courier New]interface[/font]之间在对于抽象类定义的支持方面具有很大的相似性,甚至可以相互替换,因此很多开发者在进 行抽象类定义时对于[font=Courier New]abstract class[/font]和[font=Courier New]interface[/font]的选择显得比较随意。-L]!e0N:Y"lTo.[xM+D+v7f
其实,两者之间还是有很大的区别的,对于它们的选择甚至反映出对 于问题领域本质的理解、对于设计意图的理解是否正确、合理。本文将对它们之间的区别进行一番剖析,试图给开发者提供一个在二者之间进行选择的依据。 WX T
S:G[#z8L
tMQl7q'l
A2s
[b]理解抽象类[/b]
5ld.M }cDl
abstract class和interface在Java语言中都是用来进行抽象类(本文 中的抽象类并非从abstract class翻译而来,它表示的是一个抽象体,而abstract class为Java语言中用于定义抽象类的一种方法, 请读者注意区分)定义的,那么什么是抽象类,使用抽象类能为我们带来什么好处呢?
M@%TxW/Wvw%`
Q"Zi3I0W-Hb5M{
在 面向对象的概念中,[color=red]我们知道所有的对象都是通过类来描绘的,但是反过来却不是这样。并不是 所有的类都是用来描绘对象的,如果一个类中没有包含足够的信息来描绘一个具体的对象,这样的类就是[b]抽象类[/b]。[/color]抽象类往往用来表征我们在对问题领域进行分析、 设计中得出的抽象概念,是对一系列看上去不同,但是本质上相同的具体概念的抽象。;yP G8?D
a/O
*dP5Gsd
比如:如果我们进行一个图形编辑软件的开发,就会发现问题领域存在着圆、 三角形这样一些具体概念,它们是不同的,但是它们又都属于形状这样一个概念,形状这个概念在[b][u]问题领域[/u][/b]是不存在的,它就是一个抽象概念。正是因为抽象的概念 在问题领域没有对应的具体概念,所以用以表征抽象概念的抽象类是不能够实例化的。
pP)|YQL[ w7q3T,|
!w({%Xm3V.tuw
在面向对象领域,抽象类主要用来进行[b][u]类型隐藏[/u][/b]。 我们可以构造出一个固定的一组行为的抽象描 述,但是这组行为却能够有任意个可能的具体实现方式。这个抽象描述就是抽象类,而这一组任意个可能的具体实现则表现为所有可能的派生类。模块可以操作一个 抽象体。由于模块依赖于一个固定的抽象体,因此它可以是不允许修改的;同时,通过从这个抽象体派生,也可扩展此模块的行为功能。熟悉[font=Courier New]OCP[/font]的读者一定知 道,为了能够实现面向对象设计的一个最核心的原则[font=Courier New]OCP(Open-Closed Principle)[/font],抽象类是其中的关键所在。
x7l-vYe*@1WqA
sp0aP]"C$W|
[size=3][b]从语法定义层面看abstract class 和 interface[/b][/size]
B:^I/u
`ty;a
在语法层面,Java语言对于abstract class和interface给出了不同的定义方式,下面以定义一个名为Demo的抽象类为例来说明这种不同。
/s2I}|;n6V7z k
[size=3]使用abstract class的方式定义Demo抽象类的方式如下:[/size][code]abstract class Demo
Z2S)n)}b9wB(un7xQ
{
V)~#Bpc4AP1mlg
abstract void method1();
2T/^kWPJR
abstract void method2();
$u2F3E8Fl}9_P'D
…
|FZ7CF
}[/code]使用interface的方式定义Demo抽象类的方式如下:[code]interface DemoxP
^,y8N.h:B1|r8m
{!|~fV9Xq7h
void method1();
0c%hxA7}_~$}k5K
void method2();
JPx&d