构建iOS稳定应用架构时方案选择的思考,主要涉及工程结构,数据流思想和代码规范
工程结构架构,减少耦合混乱以及防治需求大改造成结构重构,如何构建稳定可扩展可变换的工程结构的思考
我打算采用Information flow的方式自上而下,两大层分为基础层和展现层的结构。基础层分为多层,展现层也可分为多层。主要思想是将基础层的最下一层当做零部件,将业务层最下层当做组装大部件,通过流程串起来形成一个完整的产品,做零件时按照做出一个就扔进对应基础层的篮子里思路来,目录结构也可以按照这种来进行。这两大层的最下层按照零件拆得越小越容易应对需求变化越容易保护巩固上层的思路来就好。拿微信这个大家都熟悉的产品的几个功能来简单示例说明下这个思路构建后的结构,模块比较多,一些模块就不深入到最底层分析了:
基础层
- 网络
-- 收发数据
---单例(持续使用数据)
---本地(缓存和持续化存储数据对业务的封装输出)
---单次使用(API接口Model封装输出和业务逻辑封装的ViewModel,将这些做为业务零件)
- 存储
--- NSUserDefault(对轻量需要存储的添加下一层业务零件封装)
--- keychain(对安全级别较高需要存储的添加下一层业务零件封装)
--- 文件存储(对时效需求短的需要存储的添加下一层业务零件封装)
--- 数据库存储(对数据量大的需要存储的添加下一层业务零件封装,业务层上一层加一层封装CoreData或SQLite方便日后切换数据库用)
- 动画(下层将动画框架输出成各个可以复用的动画功能小零件)
- 视图风格
- 列表控件
-- 上拉加载更多
-- 下拉刷新
-- GuideView
- WebView控件
- AlertView
- iOS系统空间封装
-- 拍照控件
-- 通讯录
- 二维码
- 语音
- 安全
- 支付
- 统计
- 日志
展现层
- 首页
-- 订阅
-- 扫描二维码
-- 发布视频
- 列表
-- 时间轴列表
--- Listview头部封面
--- 外链情况Cell
--- 图片Cell
--- 广告插入Cell
--- 留言评论
--- 赞区域
-- 我的列表
-- 订阅列表
-- 文章列表
- 详细页
-- 分享
-- 内容区
-- 评论
- 登录
-- 注册
-- 登录
-- 忘记密码
-- 条款
-- 上传头像
-- 个人信息修改
基础层中各个模块上层可以使用类似CocoaPod或Cathage方式,下一层再对其引用进行业务封装。
这里注意最下层需要拆的粒度越细越好。减少横向依赖。类似Common这样的东西可以拆到基础层的对应模块里,比如说配置文件里和统计相关的放到基础层的统计里,网络相关的放到网络里,颜色字体放到视图风格里,不要都堆在一个文件里。再或者是各种第三方的Category也放到对应的组里,比如说UIView+Additions和UIColor+Expanded就放到视图风格这个模块中,不要专门搞个Category放所有的Category。
数据流控制模式MVC和MVCS/MVVM/VIPER的选择
其实这些都是对MVC的扩展,只是扩展的方向不同而已。VIPER把视图和数据拆得过细变相增加了复杂度很多人也都不熟也没有意愿去了解它的实现,但是模块复用却达到了最优,MVCS是这几个里对MVC优化最简单的只是把数据的存储拆开了。MVVM正好介于VIPER和MVCS之间,从ViewController里拆出来的ViewModel能够将数据经过逻辑处理用于View的显示,View有操作用过ReactiveCocoa将信号传给ViewModel来处理。
如果是我个人选择我会选择VIPER,因为它更符合细粒度模块划分的思想。但是用在团队多人开发上,还是偏向MVVM这种折中方案。MVVM按照先前对应用的结构分层,会将View和ViewController放到展现层的最下面的两层里,将ViewModel和Model放到基础层对应模块的最下面一层中。最后要说的是无论选择哪种,只要是按照减少ViewController大小,将改胖的地方放到Model或View都是可以的,招式学多后最高境界就是无招胜有招嘛,有时也不需要刻板的在一个项目中将所有的模块都按照统一的思路给框死,比如说一个模块很简单就用MVC,一般复杂就用MVVM,要是项目本身业务非常庞大可以整体采用VIPER来进行ViewController的完全拆分。
可以通过下列图表看其中的不同:
| 名称 | 逻辑和视图 | 数据 |
|---|---|---|
| MVC | View + ViewController | + Model |
| MVCS | View + ViewController + Store | + Model |
| MVVM | View + ViewController + ViewModel | + Model |
| VIPER | View + ViewController + Wireframe + Presenter + Interactor + Data Manager | + Entity(Model) |
代码规范
这块最有权威的应该是苹果自己提出的https://developer.apple.com/library/mac/documentation/Cocoa/Conceptual/CodingGuidelines/CodingGuidelines.html,按照这套来肯定是没问题的,而且首先应该遵守。代码结构主要根据不同团队的经验来做。下面举个我常用的代码结构
@property
...
#pragma mark - Life cycle
生命周期,类似addSubview和Notification的监听和销毁都放在这里 #pragma mark - Interface
接口 #pragma mark - Event response #pragma mark - Private method
如果是ViewController,这个地方就是瘦身的关键,业务和逻辑功能相关的就放到ViewModel里。 #pragma mark - Delegate
代理 #pragma mark - Getters and Setters
建议所有的Property都设置,这样修改配置会比较方便,看起来不会很混乱
转载:http://www.starming.com/index.php?v=index&view=83
构建iOS稳定应用架构时方案选择的思考,主要涉及工程结构,数据流思想和代码规范的更多相关文章
- 构建spring+mybatis+redis架构时遇到的小异常
异常一: Caused by: java.lang.NoSuchMethodError: org.springframework.beans.BeanUtils.instantiateClass(Lj ...
- 用 VIPER 构建 iOS 应用架构(1)
[编者按]本篇文章由 Jeff Gilbert 和 Conrad Stoll 共同编写,通过构建一个基础示例应用,深入了解 VIPER,并从视图.交互器等多个部件理清 VIPER 的整体布局及思路.通 ...
- Java架构师方案—多数据源开发详解及原理(二)(附完整项目代码)
1. mybatis下数据源开发工作 2. 数据源与DAO的关系原理模型 3. 为什么要配置SqlSessionTemplate类的bean 4. 多数据源应用测试 1. mybatis下数据源开发工 ...
- 用 VIPER 构建 iOS 应用架构(2)
[编者按]本篇文章由 Jeff Gilbert 和 Conrad Stoll 共同编写,通过构建一个基础示例应用,深入了解 VIPER,并从视图.交互器等多个部件理清 VIPER 的整体布局及思路.通 ...
- IT基础架构规划方案三(IT基础软件和系统规划)
IT基础软件和系统规划 操作系统选型规划方案 根据对某集团的实际调研,获取了企业业务应用系统的建设情况,随着企业信息化建设的推进,需要对各种信息化管理系统和应用系统的服务器选型进行选型规划,根据不同的 ...
- 用Model-View-ViewModel构建iOS App(转)
转载自 Model-View-ViewModel for iOS [译] 如果你已经开发一段时间的iOS应用,你一定听说过Model-View-Controller, 即MVC.MVC是构建iOS a ...
- 用Model-View-ViewModel构建iOS App
如果你已经开发一段时间的iOS应用,你一定听说过Model-View-Controller,即MVC.MVC是构建iOS App的标准模式.然而,最近我已经越来越厌倦MVC的一些缺点.在本文,我将重温 ...
- IT基础架构规划方案二(计算机系统与机房规划规划)
计算机系统规划 服务器硬件选型规划方案 根据对某集团的实际调研,获取了企业业务应用系统的建设情况,随着企业信息化建设的推进,需要对各种信息化管理系统和应用系统的服务器选型进行选 ...
- jenkins自动化构建iOS应用配置过程中遇到的问题
最近配置jenkins来自动构建iOS应用,期间遇上不少问题.在这里分享给大家,也给自己留个底,方便下次解决问题. 首先说明下基本情况,我们因为部署jenkins的机器不是Mac,所以不能安装Xcod ...
随机推荐
- poj 1985 Cow Marathon
题目连接 http://poj.org/problem?id=1985 Cow Marathon Description After hearing about the epidemic of obe ...
- MySQL使用rand函数实现随机数[转]
如何写一个语句能一下更新几百条MYSQL数据! 需要测试MYSQL数据库,里面有一个上万条数据的数据库,如何写一个PHP文件一下每次更新几百条信息,我都是写一个循环一次更新一条信息,这样我知道用WHI ...
- OSGi在淘宝内部的使用
现在基本不怎么用了,OSGi主要的价值,在实际中体现得不太明显 比如类隔离,用更简单的自定义ClassLoader也可以实现:单机多版本服务,用的场景也很少:热部署也不是很实用 但是,基于OSGi框架 ...
- 关于asp.net和iis的进程/线程问题,假如网站有1000个人访问,会产生多少个进程/线程啊
详解 ASP.NET异步 超好的文章
- 使用Groovy构建自己的脚本环境
场景 在进行Web服务端开发的时候,发布前通常需要测试一遍.对于一个大一点的项目,最好的办法是写个自动化测试程序. 以Groovy为例,写测试代码之前通常的有如下几个操作 引用相关的类库 import ...
- 网络笔记02数据解析 -1-JSON解析
1.JSON解析 1.JSON介绍 JSON是最网络传输数据最为广泛的数据格式,没有之一,出身草根,是Javascript的子集,专门负责描述数据格式.Javascript是网页开发的一种脚本语言,和 ...
- 树的基本操作java版
看了一下树的定义,一些基本的操作,遍历,获取节点数,获取深度等等..这里参考了西电版的数据结构,基本用的都是递归实现的. 很多说明代码中都有,每个方法我都测了一下,这里我把节点类BTreeNode作为 ...
- JAVABEAN EJB POJO区别
1.POJO POJO(Plain Old Java Object)这种叫法是Martin Fowler.Rebecca Parsons和Josh MacKenzie在2000年的一次演讲的时候提出来 ...
- udp 视频包网络传输花屏
视频数据传输在传输层可以选择TCP或者UDP,TCP面向连接,传输中断,发送端是知道的.TCP传输的好处是不丢包,坏处是网络不太好的情况下会越堵越严重.UDP非面向连接,发送端只管发送数据,接收端有没 ...
- CSS样式补充代码
CSS符号属性: list-style-type:none; /*不编号*/ list-style-type:decimal; /*阿拉伯数字*/ list-style-type:lower-roma ...