思考Android-MVC架构模式

MVC介绍

在维基百科中MVC模式(Model–view–controller)是软件工程中的一种软件架构模式,把软件系统分为三个基本部分:模型(Model)、视图(View)和控制器(Controller)。

MVC的用处

MVC模式的目的是实现一种动态的程序设计,使后续对程序的修改和扩展简化,并且使程序某一部分的重复利用成为可能。除此之外,此模式通过对复杂度的简化,使程序结构更加直观。软件系统通过对自身基本部分分离的同时也赋予了各个基本部分应有的功能。专业人员可以通过自身的专长分组。

MVC结构

控制器(Controller)- 负责转发请求,对请求进行处理。
视图(View) - 界面设计人员进行图形界面设计。
模型(Model) - 程序员编写程序应有的功能(实现算法等等)、数据库专家进行数据管理和数据库设计(可以实现具体的功能)。
如下图就是MVC的基本结构

mvc

从上面的图来分析MVC的走向一般是V-C-M-V这种单向的流程,在这里把触发事件当做是在V上产生的,但是按照图来分析产生事件是在C中,V只是给用户展示。在这里由于表示概念的方便和在Android的MVC架构中VC的区别不明显,所以把产生事件放在V中,方便在这里解释。

我所认识的MVC

在Android的MVC中,有几种说法:

1.结构一:

M:JavaBean(实体类)
V:视图的XML配置文件
C:Activity
这种结构把实体类当做M,视图的XML当做V,然后把所有的业务逻辑放到Activity里面,这样会导致的结果就是Activity里面的逻辑过于复杂和代码非常臃肿,从维基百科对于MVC的定义来看,M用于处理业务逻辑,但是这种架构把业务逻辑放到C里面。Android中展示给用户的,也就是Activity,这里把Activity当做C显然是不合理的,M所充当的也仅仅是M的作用,所以这种结构并不能当成MVC。

2.结构二(V-C-M-C-V):

M:一个持有Activity的接口实现,用于操作数据
V:视图的XML配置文件
C:用于连接M和V的中间组件,用户控制M和更新V
这种结构Activity被当做了C用于M和V的中间件,当用户在C上触发事件,C把事件传递给M,M处理完成之后通知C更新V。但是在维基百科的MVC的结构图中,M会持有V的引用和主动更新V的。然而在这里M会去通知C去更新V。这种架构中把配置视图的XML当做V我觉得还是不合理,因为用户看到的才是V,在Android中用户看到的是Activity,所以这种结构由于C和V之间的界限不清晰,在我看来只能当做VM结构。

使用

已上两种结构并不能当做维基百科上定义的MVC结构,如果要使用的话,推荐使用第二种。在维基百科的示例图上可以看到MVC模式的走向是单向的(V-C-M-V),而在结构二中的走向是双向的(V-C-M-C-V)的,所以这里也是对MVC有疑惑的地方,在Android里面的MVC并不是官方意义上的MVC,官方中的M会持有V的引用并且直接更新V,而Andoird中M并不会和V产生直接联系,是通过C来连接M和V。

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

推荐阅读更多精彩内容