谈谈MVC模式和MVP模式

前言

最近在研究Android的MVP设计模式,经过自己的研究和参考网上的案例,对MVP设计模式也有了一定的了解,今天把自己的一些想法分享出来
参考:
泡在网上的日子
鸿洋的博客

MVC模式:

什么是MVC模式?MVC模式是一种在开发当中常见的设计模式,通过视图,模型和控制层的拆分设计,使得开发更加容易,后期也更加好维护

-M:Model(模型)Model主要是各种操作,数据结构,业务逻辑和功能的实现等
-V:View(视图)View就是在layout下的各种布局文件,这个相信很容易理解
-C:Controller(控制器)Controller就是各种Activity或Fragment,这个也很容易

三者的关系:

如图:

MVC

我们很容易看到他们三者之间都是有联系的,在开发中怎么设计呢?例如用户登录功能,xml布局文件就是view层,LoginActivity就是Controller层,model层就是登录的方法,通过btn.setOnClickListener()方法调用model层的登录方法,就完成了一个登录的功能,这就是MVC的设计模式

但是,有个问题,很多时候我们的需求并不只是简简单单的一个登录功能,还有很多复杂的处理,比如我们想在登录完成后,把当前的页面的Logo隐藏,又或者替换掉当前页面的背景,按道理来说,这些关于页面的操作是在布局页面,也就是View层,但是这些都不能再xml中去实现,只能在Activity中操作,但是Activity是属于Controller层啊,这就导致了Activity既是Controller层又是View层,讲道理,如果代码越来越多,逻辑越来越复杂,这就很尴尬了,不禁写的麻烦,维护更加头疼,还有,view层和model层是互通的,这就说明两者存在耦合性,如果是个大型的项目,显然,这是非常不好的,这就衍生出了MVP设计模式


MVP模式:

什么是MVP模式?MVP模式是MVC模式的进化,解决很多MVC的一些设计缺点,比如耦合性

-M:Model(模型)跟MVC的一样
-V:View(视图)各种Activity或Fragment,这跟MVC的有点差别了
-P:Presenter(主导期)处理用户触发事件

三者的关系:

如图:

MVP

相对MVC来言,我们发现,View和Model之间没有直接的联系,而是通过Presenter进行连接,MVP模式舍去了xml布局所在的层,并把改层放置的是Activity或是Fragment,这样,解除了MVC的耦合性的问题,对于这三者的沟通,我们主要是通过接口的方式实现,还是以登录功能为例,首先,我们在Model层以接口形式定义一个登录的方法,然后定义一个类去实现这个方法,而Presenter则去调用这个方法,然后再View层去调用Presenter的实现方法,就可以完成了登录的功能,这就避免了耦合性,也大大的优化的代码,也便于后期的维护

示例代码:

项目结构图

LoginUtil类:

public interface LoginUtil { void Login(Context context); }

LoginUtilImp类:

public class LoginUtilImp implements LoginUtil { @Override public void Login(Context context) { Toast.makeText(context,"loging",Toast.LENGTH_SHORT).show(); } }

Logining类:

public class Logining { private LoginUtil mLoginUtil; private Context mContext; public Logining(Context context){ this.mContext=context; this.mLoginUtil=new LoginUtilImp(); } public void login(){ mLoginUtil.Login(mContext); } }

MainActivity类:

mBtnLogin.setOnClickListener(new View.OnClickListener(){ @Override public void onClick(View v) { mLogining.login(); } });

总结:

MVC和MVP两者说到底最大的差别就是耦合性,随着APP的功能的增强,View层处理的东西越来越多了,为了更好地细分视图与模型的功能,所以,MVP设计模式更切近我们的开发,一个好的项目,往往都是从设计模式开始,最后,有哪里不足的欢迎指出来

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 212,657评论 6 492
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 90,662评论 3 385
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 158,143评论 0 348
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 56,732评论 1 284
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 65,837评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,036评论 1 291
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,126评论 3 410
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 37,868评论 0 268
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,315评论 1 303
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,641评论 2 327
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,773评论 1 341
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,470评论 4 333
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,126评论 3 317
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,859评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,095评论 1 267
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,584评论 2 362
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,676评论 2 351

推荐阅读更多精彩内容

  • Android 自定义View的各种姿势1 Activity的显示之ViewRootImpl详解 Activity...
    passiontim阅读 171,856评论 25 707
  • 前言 MVC、MVP、MVVM一直以来都是Android应用常见的架构模式,都是为了抽离出UI逻辑和业务逻辑。但是...
    希格斯子阅读 1,173评论 0 1
  • 相信大家对MVC,MVP和MVVM都不陌生,作为三个最耳熟能详的Android框架,它们的应用可以是非常广泛的,但...
    约书亚Luis阅读 1,236评论 0 13
  • 目录及简介 第四章 设计稿完成的那个晚上,三个人在教室里忙碌。虽然凌苗苗和张尹一直别扭着,但是只要一工作起来,就默...
    林秋千阅读 333评论 2 2
  • 人类的骗局 先不说骗局不骗局吧,说说人类怎么来的吧。 无论连篇累牍的地理大发现,还是考古研究,还是海洋生物学,基因...
    菱角满塘阅读 220评论 0 1