MVP 个人理解2

根据我的理解,画了个图

这次又看了下 较复杂点的例子。

往往一个项目有多个部份,我们可以按功能分成几个activity, 每个activity有自己的view和数据model,因此也有自己的逻辑 presenter,, 如果真正能够按照 M V P模式来组建一个工程,那么整个项目思路将会十分清晰,并且每个MVP 三个方面的工作量都会非常少,而且能逻辑清晰地去写代码。

上一篇的解析,逻辑方面应该是正确的,但并非什么数据,都由一个model来存放,不同的数据应该有不同的model,比如学生跟老师,presenter和view接口也一样,不同的作用和不同的实现就有不同的presenter和view,并且可以实现重用,比如研究生和本科生可以用同一个模板presenter,只需将model的数据改变一下而已,这将会减少重复的工作,体现重用的思想。

这次觉得有点乱乱的,不知道要如何表达,也没再学到更多东西了。不过画了个图,以后看到也会更清晰了。。。。下面就借鉴一下别人的总结吧。。。。

在MVP里,Presenter完全把Model和View进行了分离,主要的程序逻辑在Presenter里实现。而且,Presenter与具体的View是没有直接关联的,而是通过定义好的接口进行交互,从而使得在变更View时候可以保持Presenter的不变,即重用!

MVP的优点

  1、模型与视图完全分离,我们可以修改视图而不影响模型。

  2、可以更高效地使用模型,因为所有的交互都发生在一个地方 —— Presenter内部。

  3、我们可以将一个Presener用于多个视图,而不需要改变Presenter的逻辑。这个特性非常的有用,因为视图的变化总是比模型的变化频繁。

  4、如果我们把逻辑放在Presenter中,那么我们就可以脱离用户接口来测试这些逻辑(单元测试)。

  MVP的缺点

  由于对视图的渲染放在了Presenter中,所以视图和Persenter的交互会过于频繁。还有一点需要明白,如果Presenter过多地渲染了视图,往往会使得它与特定的视图的联系过于紧密。一旦视图需要变更,那么Presenter也需要变更了。比如说,原本用来呈现Html的Presenter现在也需要用于呈现PDF了,那么视图很有可能也需要变更。

MCP与MVC的不同

http://www.360doc.com/content/12/0405/13/8101845_201083284.shtml

MVP 个人理解2

时间: 2024-10-27 12:41:22

MVP 个人理解2的相关文章

android开发-mvp模式理解

看之前,先忘掉所有,一步步看就行了. 最后会有一个原型demo,当然是转的了.看完文章,再看demo,然后再回头看文章就很好理解了,最好自己写一遍. 1.mvp开发模式可以理解为页面接口编程,每一层的骨架都是先通过建立接口,定义每层的必要方法,再实现方法完成的. 2.在mvp开发模式中,把每个模块代码分为三个层,View,presenter,model层. 3.view层从字面意义上理解,就是视图层,在安卓的mvp开发模式中,把activity,fragment,等 一些界面显示看作是视图层,在

MVP模式(2) 你真的理解下抽象类和接口吗??

转载请注明出处:王亟亟的大牛之路 礼拜5下午,有一些小伙伴在讨论关于"我对MVP的理解啊","我对RxJava,RxAndroid的理解啊"等等.在交流中发现,其实我们往往在实际开发中有意无意的都可能出现某个类特别的繁杂,代码特别的多,而且其实很多都是重复的,但是又没有办法,诸如一大堆回调. 可能在项目构建之初,想着我要如何如何去实现,如何如何优化代码结构,逻辑等等,可是因为理解或者业务繁重等各个因素,导致到后来还是挤成一坨龙猫,像这样(麦麦胖的脚都看不见了,臃肿,

MVC和MVP

Model View Presenter vs Model View Controller简介 在我工作中经常需要处理一些由于开发人员没能很清楚地理解MVC和MVP模式的区别的情况下使用它们而产生的问题.在这篇文章中我将会阐述一下我对两者之间区别的一些理解.在N层体系结构中MVC/P 模式仅仅只是用于表示层(presentation layer),理解这一点很重要.这两个模式并不是关于怎么构建数据层(data layer)和服务层(service layer)的,而是关于怎么将数据(data)从

[转]从三层架构到MVC,MVP

本来是不想跳出来充大头蒜的,但最近发现园子里关于MVC的文章和讨论之风越刮越烈,其中有些朋友的观点并不是我所欣赏和推荐的,同时最近也在忙着给公司里的同事做MVC方面的“扫盲工作”.所以就搜集了一些大家接触MVC的过程中经常出现的问题做了一下解释说明,希望能与大家多多交流,呵呵. 当然这种架构模式本身的一些问题也会在接下来的内容就加以介绍,另外就是如果大家有什么不同观点的话,欢迎拍砖(只要不打脸就行,呵呵). 一.  MVC是谁提出的         模型-视图-控制器(MVC)是Xerox PA

一张图看Google MVP设计架构

这段时间看了一下Google官方推出的MVP架构案例,决定把对MVP的理解用类图的形式表述一下.MVP架构的设计思想确实非常值得学习,大家如果还不是很了解MVP,建议抽时间去研究研究,相信对大家的架构设计能力和编码能力都会有所提高.当然,除了Google官方的案例,网上也有很多关于MVP架构的技术文章和案例,大家可以搜一搜,看一看,学习学习!好了,我就不赘述MVP的设计思想了,直接上图! 以上就是我对Google MVP架构的一个简单认识,目前可能还理解得不够深刻,如果以后有了更深刻的领悟,我会

Android MVP模式的初识

  MVP是什么?或许在之前更多的人知道的是MVC这个模式(Model View Controller),然而MVP与MVC最不同的一点是M与V是不直接 关联的也是就Model与View不存在直接关系,这两者之间间隔着的是Presenter层.个人感觉这是一种很棒的设计,让代码能够实现充分的解耦. 那么我们还是没有讲到MVP是什么~~~不要急,我会用最简单的方式来叙述,这样好理解~ M(Model):为UI层提供数据,或者是保存UI层的数据: V(View) :单纯的数据展示,响应用户的操作并且

MVC和MVP的区别

MVC和MVP到底有什么区别呢? 从这幅图可以看到,我们可以看到在MVC里,View是可以直接访问Model的!从而,View里会包含Model信息,不可避免的还要包括一些业务逻辑. 在MVC模型里,更关注的Model的不变,而同时有多个对Model的不同显示,及View. 所以,在MVC模型里,Model不依赖于View,但是View是依赖于Model的.不仅如此,因为有一些业务逻辑在View里实现了,导致要更改View也是比较困难的,至少那些业务逻辑是无法重用的. Visual Studio

结合实例分析Android MVP的实现

最近阅读项目的源码,发现项目中有MVP的痕迹,但是自己却不能很好地理解相关的代码实现逻辑.主要原因是自己对于MVP的理解过于概念话,还没有真正操作过.本文打算分析一个MVP的简单实例,帮助自己更好的理解MVP的内在思想. 对于什么是MVP,MVP和MVC的区别,MVP的有点,大家可以参考这篇文章:MVP 模式简单易懂的介绍方式.文章里面还有demo,可以帮助大家更好的理解. 今天分析的是一个别人写的 demo,其实作者也有写文章来介绍(Android MVP with Fragment and

MVC 与 MVP 并无两样

关于 MVC 的定义介绍,摘一段百度百科介绍: MVC 是一种使用 MVC(Model View Controller 模型-视图-控制器)设计创建 Web 应用程序的模式: Model(模型)表示应用程序核心(比如数据库记录列表). View(视图)显示数据(数据库记录). Controller(控制器)处理输入(写入数据库记录). 简单也可以这样理解,View 单纯负责 UI,如果要更新 UI 数据,则去调用 Controller,让 Controller 去控制 UI ,Controlle