单一职责原则SRP(Single Responsibility Principle)

定义: 就一个类而言,应该仅有一个引起它变化的原因。[ASD]

简单地说:

  • 一个类中应该是一组相关性很高的函数,数据的封装。这满足高内聚的要求
  • 两个完全不一样的功能就不应该放在同一个类中。
  • 例如:ImageLoader中ImageLoader类只负责加载图片逻辑,ImageCache只负责图片缓存逻辑

开放-封闭原则OCP(Open-Close Principle)

定义: 软件中的对象(类, 模块, 函数等)应该对于扩展是开放的, 但是对于修改是封闭的.[ASD]

简单的说:

  • 在我们写代码时候,假设变化不会发生.当发生变化时,我们就常见抽象来隔离以后发生同类变化.
  • 当软件需求发生变化,尽量通过扩展的方式来实现变化,而不是通过修改已有代码来实现.

例如:
最初的ImageLoader只有内存缓存MemoryCache,为了需求,添加了磁盘缓存DiskCache,后来又加入了双缓存,每一次添加一种缓存方式,都要修改ImageLoader的代码.可以将缓存类抽象成一个接口ImageCache,提供一些接口方法以上三种缓存都实现这个接口,并实现接口方法.在ImageLoader添加一个依赖注入的方法setImageCache(ImageCache imageCache);

里氏替代原则LSP(Liskov Subsitution Principle)

定义: 所有引用基类的地方必须能透明的使用其子类的对象

简单的说:

  • 只要父类出现的地方,子类都可以出现,而且替换为子类也不会产生任何错误或异常

例如:
Shape是Renctangle的父类, Shape shape = new Shape();可以替换为Shape shape = new Renctangle();而不产生错误或异常.

依赖倒置原则DIP(Dependence Inversion Principle)

定义:

  • 高层模块不应该依赖底层模块.两个都应该依赖抽象
  • 抽象不应该依赖细节. 细节应该依赖抽象.

    简单地说:

    • 抽象就是指接口或抽象类
    • 细节就是指实现类
    • 高层模块就是调用端
    • 底层模块就是具体实现类
    • 模块间的依赖通过抽象发生,实现类之间不发生直接的依赖关系,其依赖关系是通过接口或抽象类产生的.

接口隔离原则ISP(InterfaceSegregation Principle)

定义: 类间的依赖关系应该建立在最小的接口上

简单的说:

-