面向对象:单一任务原则(SRP)

Robert C. Martin提出的面向对 象的5个原 则 , 这 次介 绍 一下单一 责 任原 则 。 单 一 责 任原 则 (Single Responsibility Principle (SRP)): 类 的 责 任只有一个,修改 类 的理由不能存在多个。

参考文档(http://www.objectmentor.com/resources/articles/srp.pdf )

 
遵循SRP单 一 责 任原 则 的 类满 足以下条件: 
  ◇ 只拥 有一个角色( 责 任) 
  ◇ 修改类 的 场 合,修改的理由只有一个 
 
为 什么要去 类 的 责 任是 单 一的呢? 
假设 一个 类 有复数个 责 任, 类 修改的 时 候有2个以上的理由。其中某一个机能修改的 时 候很容易影响到其他机能。 软 件的安定性和 维护 便利性很会 较 差。 
SRP单 一 责 任原 则 中"修改的理由= 责 任" 这样 定 义 。即使理 论 明白但在 实 践中判断是比 较 困 难 的。 
下面以打电话举 例 说 明: 
Modem.java
interface Modem {
    public void dial(String pno);    //拨打 
    public void hangup();          //挂电话 
    public void send(char c);     //送信
    public char recv();           //收信
}
这样定义的Modem接口 看起来是一组机能,实质上是两组机能。 
   ◇ 连接管理 (dial、hangup) 
    ◇ 数据送受信(send、recv)
为什么这边要分为两组机能呢?
假设 Modem有以下修改: 
   ◇ 连接方法的修改  ⇒ Modem 类修改 
   ◇ 送受信方法的修改 ⇒ Modem类修改 
因此对应相对的变化,这边作为两组机能。
 
这样我们就可以重新定义如下 : 
连接管理接口: 
    Connection {dial, hangup}
数据送受信接口: 
    DataChannel {send, recv}
然后具体的实现 交 给继 承接口的各自的 类 去 实现 。 
一般来说, SRP 单一责任原则类的设计可以通过以下步骤来实现: 
  ①寻找机能 :有什么 样的机能? 
  ②汇总机能(定义类) :相似的机能 归总到一个类 
  ③考虑修改理由 :列 举类可能的修改理由 
  ④分割类:如果类有多个修改理由的场合,把类分割成多个类。或者是多个类因只有一个修改理由而汇总成一个类。 


本文来自CSDN博客,转载请标明出处:http://blog.csdn.net/hantiannan/archive/2009/09/23/4583691.aspx

posted @ 2010-03-10 12:28  玩玩乐乐  阅读(465)  评论(1编辑  收藏  举报