|
|
|
|
移动端

臧成威:美团点评客户端基于响应式的架构实践

近年来,由于移动客户端的业务复杂度越来越高,而移动客户端处理的逻辑又基本是异步逻辑,这就需要一种更好的形式来处理大量的异步的情况,减少状态并尽量使用声明的方式来书写代码实现需求,而响应式恰好能否帮助解决这些异步问题,所以,响应式的开发方式正在被越来越多的开发者接受。

作者:赵立京来源:51CTO|2018-04-04 09:30

技术沙龙 | 邀您于8月25日与国美/AWS/转转三位专家共同探讨小程序电商实战

【51CTO.com原创稿件】近日,51CTO记者对美团点评iOS技术专家臧成威进行了专访,一起探讨了美团点评客户端基于响应式的架构实践。

【讲师简介】

臧成威

美团iOS高级技术专家臧成威

臧成威,美团点评iOS高级技术专家。2012年开始接触移动互联网,曾从事Android内核订制研发和iOS 应用开发。2013加入CSDN,开始接触全栈开发Ruby on Rails框架。 2014年加入百度任职高级工程师。2015年3月加入美团点评iOS团队。

近年来,由于移动客户端的业务复杂度越来越高,而移动客户端处理的逻辑又基本是异步逻辑,这就需要一种更好的形式来处理大量的异步的情况,减少状态并尽量使用声明的方式来书写代码实现需求,而响应式恰好能否帮助解决这些异步问题,所以,响应式的开发方式正在被越来越多的开发者接受。

美团点评iOS客户端基于响应式架构的诞生

美团点评iOS团队是国内较早使用ReactiveCocoa(简称RAC)函数响应式库的团队。臧成威老师自2015年加入美团点评开始,就积极的对内外进行RAC的使用和原理的指导培训。

但是经过2年多的发展,美团点评iOS团队意识到整个团队对函数响应式编程的学习成本投入太大,对排错等成本的投入也过于庞大。

基于对函数式编程和函数响应式编程多年的理解和分析,臧成威老师认为对于工程化而言,面向对象编程才是最简单且容易被接受的,但是又需要一个响应式的能力。所以利用普通的面向对象设计来实现响应式库的想法就萌生了。

响应式库EasyReact建成后,为了能使其得到更好的利用,更好地降低使用的理解和学习成本,臧成威老师又带领团队开发了基于响应式的MVVM框架:EasyMVVM。

基于响应式的架构简述

首先,架构的最下层提供了一套基于OOP的响应式基础库EasyReact。它使用图的数据结构,构建了有向有环图。当节点值产生变化的时候,它会顺势传播到所有的边上,进而改变其他的节点值。同时,每个节点一对多关系的关联了监听者,当值发生改变时,监听者就能异步的得到反馈,这就解决了响应问题。同时它也能够让两个层级有了基本的绑定关系。

但是单有EasyReact还远远不够,如果没能在其上层建立一套完整的MVVM框架,开发者就难以有一个整体的思路。所以上层的垂直分层框架EasyMVVM促使大家的逻辑能够各司其职的放置于各个层级之内。

说到打造架构过程中遇到的难题,臧老师表示,其实打造一套全新的响应式基础库EasyReact并不是很难,因为它位于下层,并且没有其他的依赖。但是在打造其上层框架EasyMVVM的时候,为了满足View层的需要,就必须要依赖现有的UIKit框架。UIKit中大量API都是基于delegate模式来封装的,然而这和响应式编程的前置声明理念刚好相反。

为了解决这一问题,美团点评iOS团队封装了一些全新的,不基于delegate的UI组件,将声明式的接口提供给大家。同时还使用组合优于继承的形式提供了组件模块化方案,方便大家将不同的业务逻辑分离,达到复用的目的。

架构:为业务而生

最后,臧老师从生产环节、用户使用环节和线上收集环节三方面讲述了架构的研发方向。

从生产的角度来看,架构的研发方向就是自动化生成和可视化编程,所见即所得等。

从用户使用环节的角度来看,架构的研发方向就是动态化的部署和热更新的能力等。

从线上收集的角度来看,架构的研发方向就是动态埋点,自动埋点等。

【51CTO原创稿件,合作站点转载请注明原文作者和出处为51CTO.com】

【责任编辑:赵立京 TEL:(010)68476606】

点赞 0
分享:
大家都在看
猜你喜欢

读 书 +更多

Linux编程技术详解

本书全面介绍了Linux编程相关的知识,内容涵盖Linux基本知识、如何建立Linux开发环境、Linux开发工具、Linux文件系统、文件I/O操作、设备文...

订阅51CTO邮刊

点击这里查看样刊

订阅51CTO邮刊