美文网首页
设计模式的基本原则

设计模式的基本原则

作者: Aisen | 来源:发表于2018-07-08 00:01 被阅读34次

作为一个非科班出身的程序猿,在最开始敲面向对象的代码时,没有“六大原则”的概念。后来看的书和敲的代码越来越多,“六大原则”逐渐熟悉起来,就如最开始只知道武功招数,后来经高人指点获得内功心法,有种豁然开朗的感觉。

设计模式的基本原则

1、单一职责原则

英文名:Single Responsibility Principle(SRP)

定义:一个类中应该是一组相关性很高的函数、数据的封装。

解释:单一,即划分一个类、一个函数的职责,两个完全不一样的功能就不应该放在一个类中。

2、开闭原则

英文名:Open Close Principle(OCP)

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

解释:程序一旦完成,程序中一个类的实现只应该因错误而被修改,新的或者改变的特性应该通过新建不同的类实现,新建的类可以通过继承的方式来重用原类的代码。

3、里氏替换

英文名:Liskov Substitution Principle(LSP)

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

解释:简单来说,参数传递应使用基类。只要父类能出现的地方子类就可以出现,而且替换为子类也不会产生任何错误或异常,使用者可能根本就不需要知道是父类还是子类。但是,反过来就不行了,有子类出现的地方,父类未必就能适应。

4、依赖倒置原则

英文名:Dependence Inversion Principle(DIP)

定义:一种特定的解耦形式,使得高层次的模块不依赖于低层次的模块的实现细节,依赖模块被颠倒了

解释:简单来说,依赖抽象,不要依赖具体。高层模块不应该依赖低层模块,两者都应该依赖其抽象;抽象不应该依赖细节;细节应该依赖抽象。

5、接口隔离原则

英文名:Interface Segregation Principles(ISP)

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

解释:将非常庞大、臃肿的接口拆分成为更小的和更具体的接口,这样客户将会只需要知道他们感兴趣的方法。

6、迪米特原则

英文名:Law of Demeter(LOD)

定义:一个对象应该对其他对象有最少的了解

解释:简单来说,高内聚、低聚和。一个类应该对自己需要耦合或调用的类知道得最少,类的内部如何实现、如何复杂都与调用者或者依赖者没关系,调用者或者依赖者只需要知道他需要的方法即可,其他的我一概不关心。

工作上的应用

工作上应用比较多是:单一职责原则里氏替换

1、单一职责原则

主要是在定义类方法的时候,多考虑这个原则。

这样帮助自己定义的方法功能单一明了,减少耦合,同时提高代码的复用性。

例如:页面加载数据的方法,一般分三个方法:

(1)获取数据 getData(),返回原始数据

(2)处理数据 processDate(Data rawData),返回期望的数据类型

(3)显示数据 showData(), 显示数据在相关的UI上

PS:在最开始写代码时,写代码没有注意单一职责,一个方法包括好几个功能,不利于后续的扩展,改BUG也很痛苦。后续经同事指点,拆成多个单一功能的方法,后续用起来相当顺手:扩展方便,复用方便,更重要改BUG一针见效。

2、里氏替换

主要思想是面向接口编程。

这帮助自己更好的抽象代码、扩展业务需求。

例如:初始化RecyclerView的Adapter,可以写一个基类的数据ItemModel、一个基类的ViewHodler

public abstract class AbsItemModel {

    //用于RecycleView.getItemViewType(),根据viewType创建不同的ViewHolder
    public abstract int getType();
}

public abstract class AbsRecyclerViewHolder<T extends AbsItemModel> extends extends RecyclerView.ViewHolder {
    public AbsRecyclerViewHolder(View itemView) {
        super(itemView);
    }

    public abstract void onBindViewHolder(T model);
}

在实现Adapter的onBindViewHolder方法时调用这些基类

@Override
public void onBindViewHolder(RecyclerView.ViewHolder holder, int position) {
      //List<AbsItemModel> mDataList
     AbsItemModel model = mDataList.get(position);
     if (model == null) {
          return;
     }

     AbsRecyclerViewHolder viewHolder = (AbsPersonRecyclerViewHolder) holder;
     viewHolder.onBindViewHolder(model);
}

不同类型的ViewHolder继承这个基类ViewHolder,实现onBindViewHolder(T model):根据数据model,显示相应的UI。

后续业务扩展,如果需要其他ViewHolder,那么直接继承基类,实现抽象方法即可。

相关文章

  • 设计模式原则

    设计模式的基本原则 设计模式的基本原则非常重要,只要真正深入地理解了设计原则,很多设计模式其实就是原则的应用而已,...

  • iOS设计模式简介

    编码是门艺术 设计模式的基本原则 设计模式的类型 设计模式一般应用于复杂的项目 为什么会抽象出设计模式?设计模式是...

  • 架构师之路3-代码开发稳定之道

    设计架构基本原则 设计原则继承面向对象的设计思想,遵守设计模式基本原则 框架开发与项目开发相分离框架的开发任务是维...

  • 设计模式

    一、设计模式 概念:为解决特定场景下的问题而定制的解决方案. 二、设计模式的几大基本原则 设计模式的原则:构建可复...

  • Laravel框架学习笔记之推荐理由

    laravel国外最火的框架,语法优雅。使用了大量设计模式,框架完全符合设计模式的五大基本原则(面向对象设计模式有...

  • 设计模式(-)

    设计模式的7大基本原则: 设计模式的原则:构建可以服用,可以维护代码的经验法则 原则(一)接口隔离原则: 接...

  • 设计模式基本框架

    设计模式整体可简单描述为:六大基本原则、三大类23种设计模式。1、六大基本原则:1)单一职责原则:大到一个模块,中...

  • iOS最新大厂面试题整理

    iOS开发面试梳理(一) OC的理解与特性简述内存管理基本原则如何理解MVC设计模式如何理解MVVM设计模式Obj...

  • 设计模式的基本原则

    设计模式的基本原则是软件设计的编程思想,是前人总结的出设计模式的核心原则 一、单一职责原则 单一职责原则:不要存在...

  • 第二十四周 设计模式

    话题:设计模式 如何理解设计模式的几大基本原则(单一职责、开闭原则等),你平时在工作中都用过哪几种模式,可以举一个...

网友评论

      本文标题:设计模式的基本原则

      本文链接:https://www.haomeiwen.com/subject/kgynuftx.html