设计模式之禅之六大设计原则-单一职责原则

单一职责原则
--->类从属性维度的划分:名词属性,动作属性。例如。用户类(User),用户行为类。(UserService)
--->类和接口的设计原则要追求的目标是:有且仅有一个原因能引起它的变化。也就是一个接口或类只有一个职责,它就负责同一类的事情,如果所负责的业务超过两类或两类以上,则考虑拆分成不同的接口。


单一职责原则的好处
--->类的复杂性降低,实现什么指责都清晰明确的定义
--->可读性提高,因为复杂性降低,因此刻度性提高。
--->可维护性提高,因为可读性提高,因此可维护性降低
--->变更引起的风险降低,变更是必不可少的。如果接口的单一职责做的好,一个接口修改,只对相应的实现类有影响,对其他接口无影响。这对系统的扩展性,维护性都有非常大的帮助

示例:

 1 package com.yeepay.sxf.only;
 2 /**
 3  * 电话的接口类
 4  * @author sxf
 5  * 
 6  * 一个电话的业务类,看似行为只有这些。
 7  * 可是(1)拨打电话,是需要传输协议的。因此,该业务类隐含负责了通信协议的传输。
 8  *           (2)通话时,是数据的传输。因此,该业务类隐含负责了数据的传输。
 9  * 因此该电话业务类,违背了单一职责的原则,该业务类负责协议和数据两个职责。
10  * 
11  * 我们面向接口的编程。因此可以拆分成两个接口类。一个通信协议的传输接口。一个数据格式的接口。
12  * ==>可由一个实现类,同时实现这两个接口,内部组合,完成电话功能。
13  * ==>也可以由两个实现类,各自实现一个接口。然后两个实现类,数据传输类引用通信协议传输接口,(增加类的数量,增加了类之间的耦合度)
14  *         在需要打电话,先调用通信协议的方法,建立链接。再传输数据。完成通话
15  * 
16  *
17  */
18 public interface IphoneService {
19 
20     /**
21      * 拨通电话
22      * @param phoneNumber
23      */
24     public void dial(String phoneNumber);
25     /**
26      * 进行通话
27      * @param o
28      */
29     public void chat(Object o);
30     /**
31      * 通话完毕,挂断电话
32      */
33     public void hangup();
34 }
View Code
原文地址:https://www.cnblogs.com/shangxiaofei/p/4836436.html