单一职责原则(SRP:Single responsibility principle)又称
单一功能原则,面向对象五个基本原则(SOLID)之一。它规定一个类应该只有一个发生变化的原因。该原则由罗伯特·C·马丁(Robert C. Martin)于《
敏捷软件开发:原则、模式与实践》一书中给出的。马丁表示此原则是基于
汤姆·狄马克(Tom DeMarco)和Meilir Page-Jones的著作中的
内聚性原则发展出的。
就一个类而言,应该仅有一个引起它变化的原因。应该只有一个职责。每一个职责都是变化的一个轴线,如果一个类有一个以上的职责,这些职责就
耦合在了一起。这会导致脆弱的设计。当一个职责发生变化时,可能会影响其它的职责。另外,多个职责耦合在一起,会影响
复用性。例如:要实现
逻辑和界面的分离。
如果一个类承担的职责过多,就等于把这些职责
耦合在一起了。一个职责的变化可能会削弱或者抑制这个类完成其他职责的能力。这种耦合会导致脆弱的设计,当发生变化时,设计会遭受到意想不到的破坏。而如果想要避免这种现象的发生,就要尽可能的遵守单一职责原则。此原则的核心就是
解耦和增强
内聚性。
T负责两个不同的职责:职责P1,职责P2。当由于职责P1需求发生改变而需要修改类T时,有可能会导致原本运行正常的职责P2功能发生故障。也就是说职责P1和P2被
耦合在了一起。
单一职责原则并不是一个孤立的
面向对象设计原则,它是
面向对象设计五个基本原则(SOLID)之一。这些原则是:单一职责原则、
开闭原则、
接口隔离原则、
里氏替换原则和
依赖倒置原则。这些原则被一起应用时可以使一个
软件系统更易被维护和扩展。这些原则被典型的应用在
测试驱动开发上,并且是
敏捷开发以及自适应
软件开发等指导思想的重要组成部分。