个人总结:MVC和MVP的区别

作者: 珠穆朗玛小王子 | 来源:发表于2018-09-28 14:23 被阅读25次

前言

各位老铁,历时20天我又回来了。时间嗖嗖就到年底了,才发现自己年初的计划还没开始,所以这一段时间都在专心研究后端的技术。刚开始接触MVC和MVP的时候,一直都有一个疑问,他俩到底有什么区别呢,面试的时候也经常被问到这个问题。我们都知道后端主要使用MVC,因为平台的特殊性,Android根据MVC模式演变出MVP模式,广泛的使用在开发中。

现在让我们怎么思考一下,为什么在Android平台演变出MVP模式?

本文参考了以下两篇博客,大家可以去阅读原文:

两张图看懂Android开发中MVC与MVP的区别

MVP与MVC的异同

正文

首先看一下MVC和MVP的对比图(我直接偷来的):


对比图

通过对比图我们分析一下两种模式的特点:

MVC

View:布局的xml文件,或者纯Java写的布局,可以把页面显示的逻辑直接放在View中。

Model:数据处理层,可以直接和View进行交互。

Controller:把特定的功能逻辑抽离出来,作为控制层,保证View层和Model层的功能单一性,便于维护。

MVC模式相对比较简单,尤其是View层,我们可以通过jsp等技术直接操作页面,完成和Controlller层和Model层的交互,所以MVC的核心是在View层。

接下来我们再看看MVP模式:

MVP

View:Activity作为显示层。

Presenter:逻辑层,从Activity中抽离出功能逻辑,简化Activity的代码。

Model:数据处理层,主要负责网络请求,本地数据加载等操作,进一步简化Activity的代码。

从MVP的构成来看,Presenter和Model都是为了View层存在的,所以MVP的核心仍然是View层。

MVP的演变

刚才我们分析了MVC和MVP的构成,我们发现MVP模式相比MVC模式要复杂:

MVC的View层和Model层本身就是分离的,Controller层主要是简化View层的逻辑代码。

MVP的Presenter层和Model层都是为了拆分View层而存在的。

Activity在Android开发中扮演者重要的角色,页面显示,数据加载,各种事件,他一个人可以承担所有相关的功能。虽然通过xml方便了布局的开发,但是在与后端开发中的xml相比,他并没有承担起显示UI的责任,所以Activity变得越来越庞大,轻轻松松就可以几千行代码,非常不利于维护,为了让View层单纯的负责UI的显示,把Activity中的功能逻辑抽离出来,命名为Presenter层,把数据相关的操作(接口,本地数据库等)提取成Model层,并且直接把View层和Model层通过Presenter层解耦,进一步简化Activity的代码,防止Activity体积过大。

MVC和MVP的区别

这里主要说他们的不同点:

1、Presenter与Controller都扮演了逻辑层的角色,但是Presenter层的功能相对更复杂,因为他负责和View的双向交互,Controller只是单向的中介。因为Presenter是从View层抽离出来的,通常和View是一对一的关系,而Controller是面向业务的,往往是单例模式或者提供静态方法。

2、MVP中View和Model是不能进行通信的,虽然加重了P层的负担,但是有利于维护View层和Model层,如果条件允许,我们还可以对Presenter进一步拆分,来弥补Presenter负担过重的问题。

3、MVC中View和Model层可以直接交互,虽然方便了两者之间的交互,但是耦合性相对较高。

其他的不同点就不说了,本来两种模式的出发点就不同,不同点那肯定导出都是,细说这些其实没有什么太大意义。

总结

“Android为什么没有使用MVC,而是使用MVP?"

如果还有人再问我这样的问题,我就可以轻松的说出我自己的见解,而不是毫无底气的猜测。

没有最好的架构模式。随着业务的不断增长,为了让我们的代码变得更美观,我们可能会多种模式混合使用,再或者在原本的模式上衍生出新的模式,这就是架构的魅力。看来我这20几天还是没白学的。

马上要十一了,最后祝大家国庆愉快~

相关文章

  • 个人总结:MVC和MVP的区别

    前言 各位老铁,历时20天我又回来了。时间嗖嗖就到年底了,才发现自己年初的计划还没开始,所以这一段时间都在专心研究...

  • iOS:常见架构

    常见的架构有 MVC、MVP 和 MVVM。下面分别用代码做下演示。 MVC MVP MVP与MVC的区别在于:M...

  • MVC、MVP、MVVM

    MVC、MVP、MVVM 1、MVC和MVP的区别 区别在于MVC的MV之间可以通信,M的改变直接影响V的展示,不...

  • 2017-09-10-MVC,MVP和MVVM的区别和联系

    MVC,MVP和MVVM的区别和联系 1, MVC(Model-View-Controller)是最常见的软件架...

  • iOS面试题

    1.MVC、MVP、MVVM的区别?MVC: MVVM: MVP: 2.自动布局有哪些?(1)Autolayout...

  • Android-MVP使用beta

    MVP与MVC之间的区别 MVC View:对应于布局文件 Model:业务逻辑和实体模型 Controllor:...

  • 确认过眼神,一眼就知道是MVP!

    1、MVC 和 MVP的区别 MVC: 真正的MVC,V和M不互通的但是IOS上View还是会引用Model的数据...

  • 3分钟理解透 MVC / MVP / MVVM 异同

    MVC MVVM 和 MVP 这几种模式在现在的主流框架中被广泛应用,那他们有什么区别呢? # MVC   MVC...

  • iOS-面试题6-架构

    目录: MVC-Apple MVC-变种 MVP MVVM 分层设计 架构与设计模式的区别 一. MVC-Appl...

  • MVC、MVP、MVVM

    MVC和MVP,MVVM之间的关系 MVC和MVP的关系 我们都知道MVP是从经典的模式MVC演变而来,它们的基本...

网友评论

    本文标题:个人总结:MVC和MVP的区别

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