iOS的应用一般情况下,无非就是用户与界面间交互,形成操作指令,然后对数据进行增删改查, 发起网络请求。当业务过于复杂时,我们就可以采用分层架构设计。这样可以最大程度上解耦,这里,我们主要介绍最经典的四层架构设计模型。大体上,分别为:应用层、服务层、数据持久层和信息系统层。也有分3层的,把数据持久层和信息系统层合并成为数据层.
Tips: 我们常用的MVC、MVP、MVVM等都是属于应用层内的架构,也就是说,它们主要是为应用层解耦等。而本文提到的分层架构是针对整个项目而言。
而架构设计是宏观的、全面的将设计组织起来解决整个应用系统的方案。架构设计是人们对一个结构内的元素及元素间关系的一种主观映射的产物。一个好的架构设计有着良好的可复用性和可扩展性,这样可以满足用户不断变化的需求。
在软件架构设计中比较典型的一种就是分层架构设计,它采用层次划分方式,层次之间是松耦合的,层次内部是高内聚的。下图为iOS分层架构设计:
iOS信息处理应用分层架构设计
表示层:UIKit Framework构成,如视图、控制器、控件、事件处理等。用户和系统交互的组件集合。用户通过提交请求或者发出指令,系统接收用户的请求或者指令,然后将请求或者指令调往下一层,最终将结果返回这一层。表示层是用户交互和数据的展示,不应具有业务逻辑。
业务逻辑层:接收处理表示层的指令和数据,进行业务逻辑处理,并将结果返回表示层。一般由Controller/presenter/viewModel调用.
数据持久层:网络数据的访问或者本地数据访问。数据持久层用于访问信息系统层,即访问数据库或发起请求。一般封装获取数据的方法, 比如发起请求, 读取磁盘文件, 读取数据库之类.
信息系统层:系统数据来源,如数据库、文件、网络数据等。
这是一个层次分明上下层关系。我们在开发的时候应该通盘考虑好每层应该做什么, 合理的把代码分到不同的层级中, 这样vc中才不会过于沉重, 提高系统的复用性和扩展能力。