2007-07-21

为什么在Java编程中的继承多数是有害的

来源: 赛迪网 作者:佚名 评论 0 条
 

多数好的设计者象躲避瘟疫一样来避免使用实现继续(extends 关系)。实际上80%的代码应该完全用interfaces写,而不是通过extends。“Java设计模式”一书具体阐述了怎样用接口继续代替实现继续。这篇文章描述设计者为什么会这么作。

Extends是有害的;也许对于Charles Manson这个级别的不是,但是足够糟糕的它应该在任何可能的时候被避开。“JAVA设计模式”一书花了很大的部分讨论用interface继续代替实现继续。

好的设计者在他的代码中,大部分用interface,而不是具体的基类。本文讨论为什么设计者会这样选择,并且也介绍一些基于interface的编程基础。

接口(Interface)和类(Class)?

一次,我参加一个Java用户组的会议。在会议中,Jams Gosling(Java之父)做发起人讲话。在那令人难忘的Q&A部分中,有人问他:“假如你重新构造Java,你想改变什么?”。“我想抛弃classes”他回答。在笑声平息后,它解释说,真正的问题不是由于class本身,而是实现继续(extends) 关系。接口继续(implements关系)是更好的。你应该尽可能的避免实现继续。

失去了灵活性

为什么你应该避免实现继续呢?第一个问题是明确的使用具体类名将你固定到特定的实现,给底层的改变增加了不必要的困难。

在当前的灵敏编程方法中,核心是并行的设计和开发的概念。在你具体设计程序前,你开始编程。这个技术不同于传统方法的形式----传统的方式是设计应该在编码开始前完成----但是许多成功的项目已经证实你能够更快速的开发高质量代码,相对于传统的按部就班的方法。但是在并行开发的核心是主张灵活性。你不得不以某一种方式写你的代码以至于最新发现的需求能够尽可能没有痛苦的合并到已有的代码中。

胜于实现你也许需要的特征,你只需实现你明确需要的特征,而且适度的对变化的包容。假如你没有这种灵活,并行的开发,那简直不可能。

对于Inteface的编程是灵活结构的核心。为了说明为什么,让我们看一下当使用它们的时候,会发生什么。考虑下面的代码:

 f() 

  { 

  LinkedList list = new LinkedList(); 

  //... 

  g( list ); 

  } 



  g( LinkedList list ) 

  { 

  list.add( ... ); 

  g2( list ) 

  }

假设一个对于快速查询的需求被提出,以至于这个LinkedList不能够解决。你需要用HashSet来代替它。在已有代码中,变化不能够局部化,因为你不仅仅需要修改f()也需要修改g()(它带有LinkedList参数),并且还有g()把列表传递给的任何代码。象下面这样重写代码:


(本文仅表明作者个人观点,不代表本站及其管理员立场.) 推荐 收藏 投稿 打印 返回 关闭
上一篇:C 和C#的语法和功能区别  
下一篇:Java学习过程中应该理解的一些重点内容
    评论加载中…
f() 

  { 

  Collection list = new LinkedList(); 

  //... 

  g( list ); 

  } 



  g( Collection list ) 

  { 

  list.add( ... ); 

  g2( list ) 

  }
共2页: 上一页 1 [2] 下一页
 推荐文章
     

网站首页  -  网站地图 -   站长论坛  -  网站投稿  -    -  网站管理
Copyright © 2008 芜湖站长站 All Rights Reserved 皖ICP备07500611号