观察者模式在MVP中的应用

本文探讨了在Android项目中,如何利用MVP模式和观察者模式进行重构,以解决复杂的UI和逻辑耦合问题。通过实例展示了在增加新需求时,观察者模式如何帮助实现一对多的UI更新,降低代码复杂性和维护成本,提高代码可读性和可测试性。
摘要由CSDN通过智能技术生成

一、要实现的效果

  首先简单介绍一下我在项目中为什么需要使用观察者模式加MVP模式
  1、为什么使用MVP模式:下图是我所开发项目的一个主要功能界面(骑行界面),从图中我们可以看到这个界面有很多控件,比如温度、电量、当前速度、蓝牙、锁车、里程···在我重构之前所有的代码都放在了一个Activity里面,UI更新与逻辑实现全部混合在一起,有2300多行,每次需要改动时都很麻烦,查找很不方便。所以重构时决定采用MVP模式,将UI更新与逻辑实现进行解耦。
骑行界面
  2、为什么使用观察者模式:使用MVP模式之后很好地实现了更新UI与逻辑实现的解耦,本来已经可以了。但是后来又增加了一个新需求:增加一个简便操作界面,简便操作界面如下图所示:
简便操作界面
可以看到简便操作界面就是在前一个界面的基础上,UI风格完全改变,功能相对于前一个界面有所减少,但是也增加了一些新功能。简便操作界面跟骑行界面功能上很多都是重合的,因此很明显我们需要重用逻辑代码,因为我们使用了mvp模式,所以我们的UI跟逻辑本身已经实现了分离,现在关键是当逻辑处理完之后,我们需要更新UI,那么用哪种方式更新UI好呢,因为有2个界面的UI需要更新。这里我使用了观察者模式,为什么使用观察者模式?从观察者模式的定义你大概可以看出使用它的原因了:++“有时被称作发布/订阅模式,观察者模式定义了一种一对多的依赖关系,让多个观察者对象同时监听某一个主题对象。这个主题对象在状态发生变化时,会通知所有观察者对象,使它们能够自动更新自己。”++
一个逻辑处理完了之后,比如获取温度,我们需要更新两个UI,这是一种一对多的关系,因此适合使用观察者模式。

二、MVP模式简要介绍

  MVP把Activity中的UI逻辑抽象成View接口,把业务逻辑抽象成Presenter接口,Model类还是原来的Model。
  MVP模式的作用 :
1、分离了视图逻辑和业务逻辑,降低了耦合
2、Activity只处理生命周期的任务,代码变得更加简洁
3、视图逻辑和业务逻辑分别抽象到了View和Presenter的接口中去,提高代码的可阅读性
4、Presenter被抽象成接口,可以有多种具体的实现,所以方便进行单元测试
5、把业务逻辑抽到Presenter中去,避免后台线程引用着Activity导致Activity的资源无法被系统回收从而引起内存泄露和OOM
6、UI接口中定义了更新UI的方法,presenter接口中定义了业务逻辑方法,我们从这两个接口文件中就可以一目了然地看到我们有哪些逻辑操作,有哪些UI更新方法,功能一目了然。
MVP模式类图

三、观察者模式简要介绍:

  1. 概述:
      有时被称作发布/订阅模式,观察者模式定义了一种一对多的依赖关系,让多个观察者对象同时监听某一个主题对象。这个主题对象在状态发生变化时,会通知所有观察者对象,使它们能够自动更新自己。
  2. 解决的问题:
      将一个系统分割成一个一些类相互协作的类有一个不好的副作用,那就是需要维护相关对象间的一致性。我们不希望为了维持一致性而使各类紧密耦合,这样会给维护、扩展和重用都带来不便。观察者就是解决这类的耦合关系的。
  3. 模式中的角色:
      3.1抽象主题(Subject):它把所有观察者对象的引用保存到一个聚集里,每个主题都可以有任何数量的观察者。抽象主题提供一个接口,可以增加和删除观察者对象。
      3.2具体主题(ConcreteSubject):将有关状态存入具体观察者对象;在具体主题内部状态改变时,给所有登记过的观察者发出通知。
      3.3 抽象观察者(Observer):为所有的具体观察者定义一个接口,在得到主题通知时更新自己。
      3.4具体观察者(ConcreteObserver):实现抽象观察者角色所要求的更新接口,以便使本身的状态与主题状态协调。
  4. 模式解读:
      
    4.1 观察者模式的类图
    观察者模式类图

四、结合代码讲解观察者模式在MVP模式中的应用

为方便起见,我新建一个Java工程来模拟:ObseverMvp
项目文件结构如下:
==com.zha==
Client.java[类]
==com.zha.logic==
CommLogicPresenter.java[抽象类]
ConcreteCommLogic.java[类]
IRidePresenter.java[接口]
ISimpleOperatorPresenter.java[接口]
==com.zha.ui==
CommUIView.java[抽象类]
IRideView.java[接口]
ISimpleOperatorView.java[接口]
RideActivity.java[类]
SimpleOperatorActivity.java[类]
该项目的类图如下:

  • 2
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值