工程结构架构,减少耦合混乱以及防治需求大改造成结构重构,如何构建稳定可扩展可变换的工程结构的思考

我打算采用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稳定应用架构时方案选择的思考,主要涉及工程结构,数据流思想和代码规范的更多相关文章

  1. 构建spring+mybatis+redis架构时遇到的小异常

    异常一: Caused by: java.lang.NoSuchMethodError: org.springframework.beans.BeanUtils.instantiateClass(Lj ...

  2. 用 VIPER 构建 iOS 应用架构(1)

    [编者按]本篇文章由 Jeff Gilbert 和 Conrad Stoll 共同编写,通过构建一个基础示例应用,深入了解 VIPER,并从视图.交互器等多个部件理清 VIPER 的整体布局及思路.通 ...

  3. Java架构师方案—多数据源开发详解及原理(二)(附完整项目代码)

    1. mybatis下数据源开发工作 2. 数据源与DAO的关系原理模型 3. 为什么要配置SqlSessionTemplate类的bean 4. 多数据源应用测试 1. mybatis下数据源开发工 ...

  4. 用 VIPER 构建 iOS 应用架构(2)

    [编者按]本篇文章由 Jeff Gilbert 和 Conrad Stoll 共同编写,通过构建一个基础示例应用,深入了解 VIPER,并从视图.交互器等多个部件理清 VIPER 的整体布局及思路.通 ...

  5. IT基础架构规划方案三(IT基础软件和系统规划)

    IT基础软件和系统规划 操作系统选型规划方案 根据对某集团的实际调研,获取了企业业务应用系统的建设情况,随着企业信息化建设的推进,需要对各种信息化管理系统和应用系统的服务器选型进行选型规划,根据不同的 ...

  6. 用Model-View-ViewModel构建iOS App(转)

    转载自 Model-View-ViewModel for iOS [译] 如果你已经开发一段时间的iOS应用,你一定听说过Model-View-Controller, 即MVC.MVC是构建iOS a ...

  7. 用Model-View-ViewModel构建iOS App

    如果你已经开发一段时间的iOS应用,你一定听说过Model-View-Controller,即MVC.MVC是构建iOS App的标准模式.然而,最近我已经越来越厌倦MVC的一些缺点.在本文,我将重温 ...

  8. IT基础架构规划方案二(计算机系统与机房规划规划)

    计算机系统规划       服务器硬件选型规划方案       根据对某集团的实际调研,获取了企业业务应用系统的建设情况,随着企业信息化建设的推进,需要对各种信息化管理系统和应用系统的服务器选型进行选 ...

  9. jenkins自动化构建iOS应用配置过程中遇到的问题

    最近配置jenkins来自动构建iOS应用,期间遇上不少问题.在这里分享给大家,也给自己留个底,方便下次解决问题. 首先说明下基本情况,我们因为部署jenkins的机器不是Mac,所以不能安装Xcod ...

随机推荐

  1. JavaScript高级程序设计之数值数组排序

    如果数组中全是Nunber类型,则可以按照数值大小排序 , , , , ]; // asc升序函数 function compareAsc(value1, value2) { if (value1 & ...

  2. iOS学习之C语言循环结构

    一.while循环    while (循环条件) {        循环体:    }    // 1.定义循环变量    int time = 1;    // 2.循环条件    while ( ...

  3. Xcode7免证书真机调试实践

    1.Open Xcode7, click menu "Xcode-Preferences-accounts" to add your AppleId; 2.According to ...

  4. [shell基础]——sort命令

    sort命令 sort是按照ASCII码升序输出,且是从首字符依次向后比较的 常见选项      -c 测试文件是否已经被排序 -r  逆向排序      -n 按照数字数值大小排序 -t  指定分割 ...

  5. MATLAB GUI程序设计中ListBox控件在运行期间消失的原因及解决方法

    在运行期间,ListBox控件突然消失,同时给出如下错误提示: Warning: single-selection listbox control requires that Value be an ...

  6. 如何写一个简单的Web Server(一)

      在本篇博文中我将介绍如何写一个Web Server.博文中大部分资料我是参考的这篇文章(http://www.linuxhowtos.org/C_C++/socket.htm),英文不错的同学可以 ...

  7. Android -- TouchEvent的分发和截获方式

    Android系统中的每个ViewGroup的子类都具有下面三个和TouchEvent处理密切相关的方法: public boolean dispatchTouchEvent(MotionEvent ...

  8. Sprint计划会议1

    会议时间:4.15.晚9点 会议地点:学一食堂2楼 会议进程 • 首先我们讨论了实验第一个Sprint1要实现的功能(用户登录及信息录入).•  之后对任务进行了认领.•  最后每个人对自己的任务进行 ...

  9. Scrum仪式之Sprint计划会议

    会议时间:4.15.晚八点 会议地点:基础教学楼二楼 会议进程 • 首先我们讨论了实验第一个Sprint1要实现的功能,我们的初期目标.•  然后我们进一步梳理了第一阶段的任务和需求.•  之后对任务 ...

  10. 基于OpenMP的矩阵乘法实现及效率提升分析

    一.  矩阵乘法串行实现 例子选择两个1024*1024的矩阵相乘,根据矩阵乘法运算得到运算结果.其中,两个矩阵中的数为double类型,初值由随机数函数产生.代码如下: #include <i ...