当前位置: 代码迷 >> 综合 >> 【设计原则和思想---单一职责(Single Responsibility Principle )】
  详细解决方案

【设计原则和思想---单一职责(Single Responsibility Principle )】

热度:38   发布时间:2023-12-17 18:59:15.0

经典的设计原则
        SOLID、KISS、YAGNI、DRY、LOD
       很多人因为对这些原则理解的不够透彻,导致在使用的时候过于教条主义,拿原则当真理,生搬硬套,反而适得其反;

SOLID原则并非单纯的1个原则,而是由5个设计原则组成的,它们分别是:单一职责原则、开闭原则、里式替换原则、接口隔离原则和依赖反转原则,依次对应SOLID中的S、O、L、I、D这5个英文字母。

单一职责

1.如何理解单一职责原则(SRP)?

        一个类只负责完成一个职责或者功能。不要设计大而全的类,要设计粒度小、功能单一的类。单一职责原则是为了实现代码高内聚、低耦合,提高代码的复用性、可读性、可维护性。

2.哪些情况下要考虑类的拆分和单一职责?

下面这几条判断原则,比起很主观地去思考类是否职责单一,要更有指导意义、更具有可执行性:

  • 类中的代码行数、函数或属性过多,会影响代码的可读性和可维护性,我们就需要考虑对类进行拆分;
  • 类依赖的其他类过多,或者依赖类的其他类过多,不符合高内聚、低耦合的设计思想,我们就需要考虑对类进行拆分;
  • 私有方法过多,我们就要考虑能否将私有方法独立到新的类中,设置为public方法,供更多的类使用,从而提高代码的复用性;
  • 比较难给类起一个合适名字,很难用一个业务名词概括,或者只能用一些笼统的Manager、Context之类的词语来命名,这就说明类的职责定义得可能不够清晰;
  • 类中大量的方法都是集中操作类中的某几个属性,比如,在UserInfo例子中,如果一半的方法都是在操作address信息,那就可以考虑将这几个属性和对应的方法拆分出来。
  • 一个类的代码行数最好不能超过200行,函数个数及属性个数都最好不要超过10个。

  相关解决方案