什么是MVC?
MVC 全名是Model View Controller,是模型(model)-视图(view)-控制器(controller)的缩写,一种软件设计典范,用一种业务逻辑、数据、界面 显示分离的方法组织代码,将业务逻辑聚集到一个部件里面,在改进和个性化定制界面及用户交互的同一时候,不须要又一次编写业务逻辑。
图解MVC(斯坦福公开课的课件)
看了上面的MVC定义和图解,对MVC有了初步的了解,特别是斯坦福这个课件,讲的很到位。可是在实际开发过程中,却感觉离MVC的标准越来越远。
我也看过一些朋友写的iOS项目,看之前问MVC,都讲的头头是道,可是在项目中却体现的不是那么好。我自己写项目也是,理论上是理解了MVC的模式,可是真去写代码,还是认为,有些地方不到位。
特别是C(我们就把UIViewController当做C来看,网上有对C的其它解释)显得别急臃肿。有时候C里面代码几千行(并非说代码过千就是不符合MVC),C干了非常多M干的事,同一时候也干了非常多V要干的事。
这几天我看了一个项目(AFNetworking的作者写的DEMO,大家能够到github上下载),认为MVC用的很到位。每一步都是很周到,M和C的对接,V和C的对接,做到很到位。
对于MVC,我说说我的理解,俗一点讲:媒婆说没得过程。M -> 男人 , V -> 女人 , C -> 媒婆。
C(媒婆) 要给 M(男人) 介绍个女朋友 V (女人),C 是一个桥梁起着对接的作用, M 和 V 本是不认识的两个人,不能直接沟通。
说媒过程是这种:C 给 M 说,第一次见女孩子,你要给女孩子准备什么礼物吧?
这个时候,M 肯定不会说,这点小事,你还来麻烦我,自己去买吧,那预计媒婆气都气死了,这事肯定成不了。(写代码的时候,不要让C干M得事)
这事必须 M 自己去做,M 买东西就是处理数据得过程。买东西怎么去买?多少钱?怎么讲价?这都是 M 自己要去干的事。终于结果是 M 买来礼物,礼物就是我们编程过程中 Model所产生的对象。
礼物买来了,M 也不认识 V ,肯定也不知道怎么送给 V,所以这个时候 C 的作用就体现出来了,M 要把 买来的礼物(Object)交给C,让C帮忙送给 V。
就这样,V 拿到礼物,认为不错,就自己用了。
回忆一下这个过程:C 发起一个请求,买礼物。M 知道之后,就去运行这件事,终于买来礼物。M 脱 C 把礼物送给V。一个完整的请求数据,展示数据的过程。
尽管有点俗,可是还是有一定道理的。
后面时间同意的话,我会具体解释一下AFNetworking的作者写的DEMO。看看MVC在项目的体现究竟是什么样的。
我的微信公众号 iOS开发 : iOSDevTip
相关文章
- Spring MVC前传递和后端接收的参数名不一致处理方式
- Java 理论和实践: 了解泛型 识别和避免学习使用泛型过程中的陷阱
- Core中的MVC和Web API的区别和用法
- SQL Server 2014存储过程的备份和还原
- 编写一个算法来判断一个数是不是“快乐数”。 一个“快乐数”定义为:对于一个正整数,每一次将该数替换为它每个位置上的数字的平方和, 然后重复这个过程直 到这个数变为 1,也可能是无限循环但始终变不到 1
- 排序算法-插入排序-初始状态: 将数组分为已排序部分和未排序部分。初始时,已排序部分只包含第一个元素,而未排序部分包含其余的元素。逐步构建有序序列: 从未排序部分取出第一个元素,将其插入到已排序部分的正确位置,使得已排序部分仍然保持有序。比较并移动: 将取出的元素与已排序部分的元素逐一比较,找到其正确的插入位置。为了插入,可能需要将比它大的元素依次向右移动,为新元素腾出插入的位置。重复步骤 2-3: 重复以上步骤,每次取出未排序部分的一个元素,插入到已排序部分的正确位置。这样,已排序部分逐渐增加,未排序部分逐渐减小。直到排序完成: 重复上述过程,直到未排序部分为空,整个数组就被排序完成了。 插入排序代码
- 软件概要设计的过程和内容
- Mybatis Mapper接口和xml绑定的多种方式、内部实现原理和过程
- TSL 和 SSL 是什么?它们有何关系?-定义:SSL(安全套接层)是一种早期的加密协议,用于在互联网通信中保障数据传输的安全性。它通过加密和身份验证机制,确保客户端(如浏览器)与服务器之间的通信不被窃听或篡改。 版本:SSL 1.0(未发布)、SSL 2.0(1995年,已废弃)、SSL 3.0(1996年,已淘汰)。 问题:SSL 3.0 及早期版本存在严重安全漏洞(如 POODLE 攻击),目前已被现代系统禁用。 2. TLS(Transport Layer Security) 定义:TLS(传输层安全协议)是 SSL 的继任者,旨在提供更安全的通信协议。TLS 由国际互联网工程任务组(IETF)标准化,逐步替代了 SSL。 版本:TLS 1.0(1999年,已淘汰)、TLS 1.1(2006年,已淘汰)、TLS 1.2(2008年,广泛使用)、TLS 1.3(2018年,最新标准)。 优势:更强的加密算法(如 AES、ChaCha20)、更高效的握手过程、支持前向保密(Perfect Forward Secrecy)等。 SSL 与 TLS 的关系 继承关系 TLS 直接基于 SSL 3.0 设计,可以视为 SSL 的升级版。TLS 1.0 最初命名为 SSL 3.1,后因标准化需要更名为 TLS。 协议兼容性
- /etc/profile ~/.bash_profile ~/.bashrc 等文件的执行过程 和 区别