Upgrade to Pro — share decks privately, control downloads, hide ads and more …

Schizo分进程自动化框架

L.J.
November 28, 2018

 Schizo分进程自动化框架

一个极其易用的响应式分进程模块框架 (基于 RxJava

L.J.

November 28, 2018
Tweet

Other Decks in Programming

Transcript

  1. 模块化与组件化 类别 目的 特点 接口 成果 架构定位 组件 重用、解耦 高重用、松耦合

    无统一接口 基础库、基础组 件 纵向分层 模块 隔离、封装 高内聚、松耦合 统一接口 业务框架、业务 模块 横向分块 • 组件:RxJava2,Retrofit,Glide,库 • 模块:账户模块,下载模块,美图业务模块,定位服务
  2. 统一接口规则 • Single<T>:用于一次请求一次返回 • 调用一个普通的接口,客户端向服务端查询一个数据 • Observable<T>:用于一次请求,分次返回 • 例如监听下载进度、监听网络变化 •

    统一 AIDL 传输格式与协议:Json String • 根据实现自动生成调用接口 @Api("person") Person getPerson(String name) { return new Person("Hello", "Schizo"); } 自动生成 public static Single<Person> person(String name) {…}
  3. 数据流 POJO(Input) Json parcel Json POJO(Input) Converter Converter AIDL AIDL

    RxBinder parcel 处理业务 POJO(Output) Json Converter parcel AIDL AIDL RxBinder parcel Json POJO(Output) Converter
  4. 接口隔离 原则 • 接口与实现分离 • 根据实现自动生成接口文件 • 实现分割到模块颗粒大小 • 维持代码边界

    • 模块独立 • Artifactory 远程仓库依赖 • 禁止外部模块耦合 • 不得互相依赖
  5. 接口设计 Schizo Annotation 响应式调用 服务 Api 参数 返回 异常 异步

    Functional Action Annotation Api Annotaion Schizo Annotation Schizo Processor Rxjava
  6. 自动生成 SchizoProcessor 根据 StartBucks 自动生成 StarBucksApi @Action("io.jween.service.starbucks") public class StartBucks

    extends SchizoService { @Api("getCoffee") Coffee makeCoffee(String name) throws Exception{ … } } 自动生成 Processor
  7. 自动生成 咖啡店接口(客户端, 自动生成, 使用者无法更改 public final class StartBucksApi { private

    static final String ACTION = "io.jween.service.starbucks"; public static void attach(Context context) { ComponentManager.attach(context, ACTION); } public static void detach() { ComponentManager.detach(ACTION); } public static Single<Coffee> getCoffee(String name) { TypeToken<Coffee> typeToken = new TypeToken<Coffee>(){}; Type type = typeToken.getType(); return ComponentManager.get(ACTION).process("getCoffee", name, type); } }
  8. 自动生成 咖啡店接口(使用 Disposable disposable = StartBucksApi.getCoffee("Cappuccino") .observeOn(AndroidSchedulers.mainThread()) .subscribe( new Consumer<Coffee>()

    { @Override public void accept(Coffee coffee) throws Exception { Log.v("StarBucks", "Purchased a cup of " + coffee.getName() + "from" + coffee.getProducer()); } }, new Consumer<Throwable>() { @Override public void accept(Throwable throwable) throws Exception { SchizoException exception = SchizoExceptions.from(throwable); int errorCode = exception.getCode(); String errorMsg = exception.getMessage(); // handle your exceptions } });
  9. 自动生成 Observable @Api("observeConnection") Observable<Boolean> observeConnection() { return networkMonitor.observeConnection(); } public

    static Observable<Boolean> observeConnection() { TypeToken<Boolean> typeToken = new TypeToken<Boolean>(){}; Type type = typeToken.getType(); return ComponentManager.get(ACTION) .processObserver("observeConnection", null, type); } CoreService CoreServiceApi 自 动 生 成
  10. 持续集成 实际项目举例 • pcore: 核心模块,单独迭代,发布到内部 Artifactory • apply plugin: 'com.meizu.publisher’

    • meizu.libGroup=com.meizu.flyme.gamecenter • meizu.libId=core • meizu.libVersion=1.2.0 • meizu.distribute=jar,aar • pappmanager: App 下载管理模块,单独迭代,依赖 pcore • implementation 'com.meizu.flyme.gamecenter:core:1.2.0' pcore pappmanager App artifactory
  11. 持续集成 • 独立开发,每个模块独立研发 • 依赖处理,gradle 处理依赖关系 • 复用模块,别的 App 也能复用我们发布的模块(考虑边界

    • 潜规则: • p 开头命名的模块表示使用了分进程 • 其余的为正常 Android Library Module • 无论分进程模块还是普通模块,通信都是一样的 • Analyze Dependencies 可以分析模块依赖关系(Gradle 红利 • ./gradlew pcore:dependencies