iOS之网络层的设计

本片文章主要讲的网络层和业务层的对接方面

我们常用的将数据交给业务层的有Delegate,Notification,Block三种方式。

我们根据:

  1. 尽可能减跨层访问限制耦合
  2. 统一回调方法,便于调试和维护
  3. 跟业务层对接只采用一种对接手段
  4. 容易追踪,容易维护
  5. 不会延长对象的生命周期
  6. 复合在离散场景下每次回调一致的规范

选择Delegate方式。

交付什么样的数据给业务层

这里有两种方式:

  1. 将网络层拿到的json数据转化为对应的对象原型(通用类型)
  2. 采用适配器模式,我添加DataFactory对象用于封装数据转化的逻辑

分析一下两种方式的优缺点:
方式1:

  1. 数组内容的转化成本较高
  2. 容易出现类型爆炸,提高维护成本

方式2:

  1. 数据会散落在各处,提高维护成本
  2. 对数据内部的key值得替换成本较高

这里我们把方式一和方式二结合使用:
以Factory作为输出的终端控制器,根据自己的需求定制不同的Factory,并在Factory内部对数据进行组装之转化为响应的对象模型。

对以上的说明:

  1. Factory是一个遵循RXBaseRequestDataReformer协议的对象
  2. Api的原始数据由manager保管,Factory方法取manager内的数据进
    行组装,转换并生成响应的对象模型
  3. 在一个view展示不同的数据的api数据的时候适宜使用Factory(因为Factory输出标准化的对象原型)

采用Factory模式的好处:

  • 处理单view对多api以及多view对多api时非常优雅,隔离转化逻辑和主体业务逻辑
  • 可以对Controller内部的代码减负,提高灵活性,只切换Factory就能满足不同的业务逻辑对数据的需要
  • 业务逻辑和业务有了适当的隔离,当业务逻辑发生改变时改变Factory即可

选择集约型API的调用方式还是离散型API的调用方式

  • 集约型API的调用方式调用的所有的API只有一个类
  • 离散型API是一个API对应一个manager,并且manager只要提供参数就可以发起请求,API的名字和着陆方式已经集成到APImanager中
  • 对于网络层的下层采用的是集约方式,对于和业务的对接层采用的是离散型的方式

采用离散化方式的优点:

  • API请求的着落点消失,离散型API可以很好的处理
  • 离散型API的调用方式可以给业务方提供灵活性

我们可以再底层采用集约化的方式进行数据请求,在业务方采用离散化的API来调用。

怎么进行APIManager的继承,

由于子类可能重写父类不允许重写的方法,所以我们提供IOP(面向接口编程)方式来限制子类的重载。
这里是我网络层封装的源码

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • iOS应用架构谈 网络层设计方案 前言 网络层在一个App中也是一个不可缺少的部分,工程师们在网络层能够发挥的空间...
    其实也没有阅读 599评论 1 1
  • 最近接触了几名小学心理辅导老师,有目的地让他们讲了讲小学生性教育的问题,没想到收获还真不小,整理了几个小故事,分享...
    岁月包进粽子阅读 4,697评论 4 8
  • (一)娃他舅 建筑队里有一个被他们唤作“娃他舅”的人,三十多岁,蓄着特朗普一样风吹一边倒的长发,胡子邋里邋遢的,远...
    明望舒阅读 443评论 0 0
  • 01 我不知道梦想有几斤几两 像小溪轻盈能爬上高山的肩膀 还是像高山雄壮不怕与江河相撞 但我知道梦想生病什么样 他...
    葡葡萄阅读 286评论 0 0
  • 本周主题《其实这个世界是有生命的》 本周主题让我想起了多年前自己在QQ写下的签名,也是我对本周主题的阐释: 生活就...
    路人夏阅读 293评论 0 0