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

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

单一职责原则
--->类从属性维度的划分:名词属性,动作属性。例如。用户类(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

 

相关文章
|
3月前
|
设计模式 PHP
PHP中的设计模式:单一职责原则在软件开发中的应用
【10月更文挑战第8天】 在软件开发中,设计模式是解决常见问题的经验总结,而单一职责原则作为面向对象设计的基本原则之一,强调一个类应该只有一个引起变化的原因。本文将探讨单一职责原则在PHP中的应用,通过实际代码示例展示如何运用该原则来提高代码的可维护性和可扩展性。
40 1
|
3天前
|
设计模式 存储 关系型数据库
「全网最细 + 实战源码案例」设计模式——六大设计原则
本文介绍了面向对象设计中的六大原则,旨在提高软件系统的可维护性、可复用性和可拓展性。这些原则包括:开闭原则(OCP)、里氏代换原则(LSP)、依赖倒转原则(DIP)、接口隔离原则(ISP)、迪米特法则(LoD)和合成复用原则(CARP)。每项原则通过具体示例展示了如何通过抽象、多态、组合等方式降低耦合度,增强系统的灵活性与稳定性,从而提升开发效率并降低成本。
20 10
|
3月前
|
设计模式 存储 测试技术
PHP中的设计模式:单一职责原则在维护性提升中的应用
【10月更文挑战第3天】 在软件开发中,设计模式是解决常见问题的高效方案。本文聚焦于PHP开发,探讨如何运用单一职责原则优化代码结构,提高系统可维护性。通过分析实际案例,本文展示了单一职责原则在降低代码复杂性、增强代码可读性和促进团队协作方面的显著效果。此外,文章还将讨论在实际项目中实施单一职责原则时可能遇到的挑战及应对策略,旨在为PHP开发者提供实用的指导和启示。
34 2
|
4月前
|
设计模式 数据管理 测试技术
PHP中的设计模式:单一职责原则在实战项目中的应用
在软件开发中,设计模式是解决问题的最佳实践。本文通过分析单一职责原则(SRP),探讨了如何运用这一原则来提升PHP项目的可维护性和扩展性。我们将从实际案例出发,展示单一职责原则在业务逻辑分离、代码解耦和提高测试效率方面的应用。无论是新手还是经验丰富的开发者,都能从中获益,进而编写出更健壮、更灵活的PHP代码。
52 5
|
4月前
|
设计模式 安全 PHP
PHP中的设计模式:单一职责原则在实战中的应用
在软件开发中,设计模式是解决常见问题的成熟方案。本文将通过分析单一职责原则这一设计原则,探讨如何在PHP应用程序中应用这一原则来提高代码的可维护性、扩展性和灵活性。我们将从实际案例出发,展示单一职责原则的具体应用方法,并解释其对项目开发周期和质量的积极影响。无论你是PHP初学者还是经验丰富的开发者,都能从中获益,提升你的编程实践水平。
39 4
|
4月前
|
设计模式 Java 测试技术
Java设计模式-UML与设计原则(1)
Java设计模式-UML与设计原则(1)
|
4月前
|
设计模式 存储 测试技术
PHP中的设计模式:单一职责原则深度解析
在软件开发的广袤天地中,设计模式如同璀璨星辰,指引着我们穿越复杂系统的迷雾。本文聚焦于PHP环境,深入探讨“单一职责原则”(SRP),这一面向对象设计的基石。不同于常规摘要的简短概述,本文将引导您逐步揭开SRP的神秘面纱,从理论精髓到实践路径,再到其在PHP中的应用实例,为您呈现一场关于代码清晰性、可维护性和扩展性的深度之旅。
|
5月前
|
设计模式 前端开发 JavaScript
React开发设计模式及原则概念问题之什么是HOC(Higher-order component),HOC遵循的设计原则都有哪些
React开发设计模式及原则概念问题之什么是HOC(Higher-order component),HOC遵循的设计原则都有哪些
|
5月前
|
设计模式 前端开发 JavaScript
React开发设计模式及原则概念问题之什么是设计模式,单一职责原则如何理解
React开发设计模式及原则概念问题之什么是设计模式,单一职责原则如何理解
|
6月前
|
设计模式 算法
交易链路设计原则&模式问题之中介者(Mediator)方法设计模式是什么,如何解决
交易链路设计原则&模式问题之中介者(Mediator)方法设计模式是什么,如何解决

热门文章

最新文章