[News] Google重写了Architecture Guide

1,100 阅读2分钟

Google在2021年底重写了architecture guide

看到这则新闻: Rebuilding the guide to app architecture 是Google官方的新闻博客, 在2021年底12月的时候发布. 说响应社区需求, 更新了app architecture guide.

包括一些best practices和建议的architecture, 让我们来看看都有什么吧.

建议的architecture

首先来看看最重要的部分, 即app架构图. new-architecture.png

仍然是遵循了架构设计的两个出发点:

  • Separation of concerns: 关注点分离.
  • Drive UI from data models: 数据驱动UI.

每个app会分三层:

  • UI层. 负责把应用数据展示在屏幕上.
  • Domain层. 这层是optional的, 可以用来简化和复用UI和data层之间的交互.
  • Data层. 包含业务逻辑, 暴露应用数据.

UI layer

UI layer也可以叫presentation layer. ui-layer.png

主要由两个东西组成:

  • UI元素: View或Jetpack Compose.
  • State holders: 比如ViewModel. 它们持有数据, 暴露给UI, 处理逻辑.

UI层的更多讨论请看: UI layer.

Data layer

Data layer包括业务逻辑: app如何创建, 存储, 改变数据.

Data layer由repositories组成, 每个repository可以有0到多个data source.

data-layer.png

Data层的单独介绍见: Data layer

Domain layer

Domain layer在UI层和data层直接, 是可选的一层, 并不是所有app都需要.

主要用途是封装复杂的业务逻辑, 或者简单的业务逻辑需要被多个ViewModel复用.

domain-layer.png

这一层的类通常被命名为use cases或者interactors. 每个use case应该有一个独立的功能.

Domain层的单独介绍见: Domain Layor

改之前是什么: MVVM

改之前的架构图是一个经典的MVVM pattern. architecture-MVVM.png 推测这波改动是想让architecture的概念更加抽象升级, 来应对更多实际问题和复杂场景.

Actions

官方提供了一个learning pathway 大家可以学起来了.

Reference