软件工程第四次作业

问:MVC与MVP的区别?
答:代码逻辑有没有写在View中的,有就是MVC,没有就是MVP
1、MVC结构示意图

在这里插入图片描述

2、MVP结构示意图

在这里插入图片描述

3、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层可以直接交互,虽然方便了两者之间的交互,但是耦合性相对较高。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

玳宸

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值