构建iOS稳定应用架构时方案选择的思考,主要涉及工程结构,数据流思想和代码规范

简介: 工程结构架构,减少耦合混乱以及防治需求大改造成结构重构,如何构建稳定可扩展可变换的工程结构的思考 我打算采用Information flow的方式自上而下,两大层分为基础层和展现层的结构。基础层分为多层,展现层也可分为多层。

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

我打算采用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

如何联系我:【万里虎】www.bravetiger.cn 【QQ】3396726884 (咨询问题100元起,帮助解决问题500元起) 【博客】http://www.cnblogs.com/kenshinobiy/
目录
相关文章
|
6月前
|
网络协议 NoSQL API
转转客服IM系统的WebSocket集群架构设计和部署方案
客服IM系统是转转自研的在线客服系统,是用户和转转客服沟通的重要工具,主要包括机器人客服、人工客服、会话分配、技能组管理等功能。在这套系统中,我们使用了很多开源框架和中间件,今天讲一下客服IM系统中WebSocket集群的的实践和应用。
564 141
|
6月前
|
消息中间件 监控 Cloud Native
高效设计:支持亿级用户社交关系的100W QPS架构方案
面对亿级用户与百万QPS的高并发场景,性能测试成为系统稳定的关键。本文剖析真实业务痛点,详解从接口压测、全链路监控到瓶颈定位的完整性能体系,助你掌握大厂级性能优化能力,从容应对卡顿、宕机等线上挑战。
|
6月前
|
存储 监控 NoSQL
Redis高可用架构全解析:从主从复制到集群方案
Redis高可用确保服务持续稳定,避免单点故障导致数据丢失或业务中断。通过主从复制实现数据冗余,哨兵模式支持自动故障转移,Cluster集群则提供分布式数据分片与水平扩展,三者层层递进,保障读写分离、容灾切换与大规模数据存储,构建高性能、高可靠的Redis架构体系。
|
边缘计算 Kubernetes 物联网
Kubernetes 赋能边缘计算:架构解析、挑战突破与实践方案
在物联网和工业互联网快速发展的背景下,边缘计算凭借就近处理数据的优势,成为解决云计算延迟高、带宽成本高的关键技术。而 Kubernetes 凭借统一管理、容器化适配和强大生态扩展性,正逐步成为边缘计算的核心编排平台。本文系统解析 Kubernetes 适配边缘环境的架构分层、核心挑战与新兴解决方案,为企业落地边缘项目提供实践参考。
607 0
阿里二面:10亿级分库分表,如何丝滑扩容、如何双写灰度?阿里P8方案+ 架构图,看完直接上offer!
阿里二面:10亿级分库分表,如何丝滑扩容、如何双写灰度?阿里P8方案+ 架构图,看完直接上offer!
阿里二面:10亿级分库分表,如何丝滑扩容、如何双写灰度?阿里P8方案+ 架构图,看完直接上offer!
|
8月前
|
缓存 Java 数据库
Java 项目分层架构实操指南及长尾关键词优化方案
本指南详解基于Spring Boot与Spring Cloud的Java微服务分层架构,以用户管理系统为例,涵盖技术选型、核心代码实现、服务治理及部署实践,助力掌握现代化Java企业级开发方案。
382 2
|
8月前
|
数据采集 边缘计算 定位技术
ar景区导航导览开发方案:核心技术架构与功能设计
本方案针对传统景区导航吸引力弱、互动性差等问题,融合三维建模、多源定位与AR引擎技术,实现室内外精准导航与AR互动体验。支持AR寻宝等功能,提升游客体验与景区竞争力。
574 0
|
8月前
|
存储 消息中间件 NoSQL
跟着大厂学架构01:如何利用开源方案,复刻B站那套“永不崩溃”的评论系统?
本文基于B站技术团队分享的《B站评论系统的多级存储架构》,解析其在高并发场景下的设计精髓,并通过开源技术栈(MySQL、Redis、Java)复刻其实现。文章深入讲解了多级存储、数据同步、容灾降级等关键设计,并附有完整代码实现,助你掌握大厂架构设计之道。
406 0
|
11月前
|
监控 NoSQL 算法
百万级URL重定向工程:大规模网站架构设计与性能优化实战
本文深入探讨了大规模重定向系统的核心挑战与解决方案,涵盖技术瓶颈分析、分布式架构设计、十亿级URL处理策略、全球化部署方案及全链路监控体系。通过数学建模与性能优化,提出三层架构模型,并结合一致性哈希分片算法实现高效路由。同时,对比不同架构的吞吐量与容灾能力,分享某电商平台实践案例,展示性能显著提升。最后展望重定向即服务(RaaS)未来趋势,包括AI动态路由、量子安全跳转和边缘智能等关键技术,为企业提供扩展性强、稳定性高的系统设计参考。
416 25