Facebook移动架构:Android Flux架构详解
要为Android应用找到一个好的架构不是一件容易的事情。谷歌似乎不太在乎这个事情,因此在设计模式上,除了Activity 生命周期管理之外,再也没有官方的推荐。 但是,为你的应用打造一个架构是非常重要的。不管你是否喜欢,任何应用终都会有一个架构。因此你好是成为一个架构的奠基人,而不是等着它出现。 : Clean Architecture 目前的趋势是采用Uncle Bob在2012年对web应用提出的建议: Clean Architecture。 但是我发现Clean Architecture对于绝大多数安卓应用来说都有点过度设计了。 通常移动应用要比web应用的生命短。移动端技术的发展太快,以至于发行的app可能在一年后已经完全过时。 移动应用所做的事情很少。绝大多数的用例都只是数据信息流的消费。从API获取数据,显示数据给用户,很少有输入与写入。 所以它的业务逻辑并不复杂。至少不如后端一样的复杂。虽然你要处理很多平台上的问题:内存,存储,暂停,恢复,网络,定位等等,但是这些都不是业务逻辑。所有app都有这些东西。 因此,绝大多数app似乎都无法从类似于复杂的分层或者工作执行优先级队列中获益。 他们也许只是需要一种组织代码的简单方式,能高效的一起工作,更容易的发现bug。 Flux 架构介绍 Flux 架构 被Facebook使用来构建他们的客户端web应用。跟Clean Architecture一样,它不是为移动应用设计的,但是它的特性和简单可以让我们很好的在安卓项目中采用。
要理解Flux,有两个关键的特点 数据流总是单向的一个单向的数据流 是 Flux 架构的核心,也是它简单易学的原因。如下面讨论的,在进行应用测试的时候,它提供了非常大的帮助。 应用被分成三个主要部分: View: 应用的界面。这里创建响应用户操作的action。 Dispatcher: 中心枢纽,传递所有的action,负责把它们运达每个Store。 Store: 维护一个特定application domain的状态。它们根据当前状态响应action,执行业务逻辑,同时在完成的时候发出一个change事件。这个事件用于view更新其界面。 这三个部分都是通过Action来通信的:一个简单的基本对象,以类型来区分,包含了和操作相关的数据。 Flux Android 架构 在Android开发中使用Flux设计规范的目的是建立一个在简单性与易扩展易测试之间都比较平衡的架构。 第一步是找到Flux元素和安卓app组件之间的映射。 其中两个元素非常容易找到与实现。 View: Activity o或者Fragment Dispatcher: 一个事件总线( event bus),在我的例子中将使用Otto,但是其它任何实现都应该是ok的。 Actions Actions也不复杂。它们的实现和POJO一样简单,有两个主要属性: Type: 一个String,定义了事件的类型。 Data: 一个map,装载了本次操作。 比如,一个显示用户详情的典型action如下: Bundle data = new Bundle(); data.put("USER_ID", id); Action action = new ViewAction("SHOW_USER", data); Stores 这可能是Flux理论中难的部分。 如果你之前使用过Clean Architecture,你可能难以接受。因为Stores承担了原本被分成多层的责任。 Stores包含了application的状态与它的业务逻辑。它们类似于rich data models但是可以管理多个对象的状态,而不仅仅是一个对象。 Stores响应Dispatcher发出的Action,执行业务逻辑并发送change事件。 Stores的输出是这单一的事件:change。其它对Store内部状态感兴趣的组件必须监听这个事件,同时使用它获取需要的数据。 系统中不再需要任何其它组建去了解application的任何状态信息。 后,stores必须对外公开一个获取application状态的接口。这样,view元素可以查询Stores然后相应的更新UI。
比如,在一个Pub Discovery App 中,SearchStore被用来跟踪被搜索的item,搜索结果以及搜索历史。在同一个应用中,一个ReviewedStore同样包含了浏览pub的列表以及必要的逻辑比如根据review排序。
免责声明:
① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。
② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341