面向对象的六大原则

本文介绍了面向对象设计的六大基本原则,包括单一职责原则、开闭原则、里氏替换原则、依赖倒置原则、接口隔离原则及迪米特原则,并通过实例展示了单一职责原则和里氏替换原则的具体应用。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

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

今天简单总结“六大原则”,以后不断扩展补充。

一、单一职责原则

英文名:Single Responsibility Principle(SRP)
定义:一个类中应该是一组相关性很高的函数、数据的封装。
解释:单一,即划分一个类、一个函数的职责,两个完全不一样的功能就不应该放在一个类中。

二、开闭原则

英文名:Open Close Principle(OCP)
定义:软件中的对象(类、模块、函数等)应该对于扩展是开放的,但是,对于修改是封闭的。
解释:程序一旦完成,程序中一个类的实现只应该因错误而被修改,新的或者改变的特性应该通过新建不同的类实现,新建的类可以通过继承的方式来重用原类的代码。

三、里氏替换

英文名:Liskov Substitution Principle(LSP)
定义:所有引用基类的地方必须能透明地使用其子类的对象。
解释:简单来说,参数传递应使用基类。只要父类能出现的地方子类就可以出现,而且替换为子类也不会产生任何错误或异常,使用者可能根本就不需要知道是父类还是子类。但是,反过来就不行了,有子类出现的地方,父类未必就能适应。

四、依赖倒置原则

英文名:Dependence Inversion Principle(DIP)
定义:一种特定的解耦形式,使得高层次的模块不依赖于低层次的模块的实现细节,依赖模块被颠倒了
解释:简单来说,依赖抽象,不要依赖具体。高层模块不应该依赖低层模块,两者都应该依赖其抽象;抽象不应该依赖细节;细节应该依赖抽象。

五、接口隔离原则

英文名:Interface Segregation Principles(ISP)
定义:类间的依赖关系应该建立在最小的接口上。
解释:将非常庞大、臃肿的接口拆分成为更小的和更具体的接口,这样客户将会只需要知道他们感兴趣的方法。

六、迪米特原则

英文名: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,那么直接继承基类,实现抽象方法即可。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值