Android滴滴路由框架DRouter原理解析_could not generate d_router table

本文详细解析了Android滴滴路由框架DRouter的初始化流程和编译期transform过程。DRouter框架分为数据流层、组件层和开放接口层。初始化涉及加载路由表,采用异步方式避免影响主线程。编译期transform通过RouterPlugin和Gradle Transform动态生成RouterLoader类,执行RouterTask完成路由表的生成。
摘要由CSDN通过智能技术生成

回答了问题4,通过减少使用反射提升了性能。

在原理和架构章节处给了一张架构的设计图:

整体架构分三层,自下而上是数据流层、组件层、开放接口层。

数据流层是DRouter最重要的核心模块,这里承载着插件生成的路由表、路由元素、动态注册、以及跨进程功能相关的序列化数据流。所有的路由流转都会从这里取得对应的数据,进而流向正确的目标。

RouterPlugin和MetaLoader负责生成路由表,路由元素指的是RouterMeta,存放scheme/host/path等信息。

组件层,核心的路由分发、拦截器、生命周期、异步暂存和监控、ServiceLoader、多维过滤、Fragment路由,以及跨进程命令打包等。

开放接口层则是使用时接触到的一些类,API设计得也很简单易用,DRouter类和Request类分别只有75和121行代码。

问题1得到解答,到此处也对整个框架有了一个整体的认识。

阅读源码
1.初始化流程

调用DRouter.init(app)后的时序图如下:

默认是在子线程实现路由表加载,不影响主线程。

public static void checkAndLoad(final String app, boolean async) {
if (!loadRecord.contains(app)) {
// 双重校验锁
synchronized (RouterStore.class) {
if (!loadRecord.contains(app)) {
loadRecord.add(app);
if (!async) {
Log.d(RouterLogger.CORE_TAG, “DRouter start load router table sync”);
load(app);
} else {
new Thread(“drouter-table-thread”) {
@Override
public void run() {
Log.d(RouterLogger.CORE_TAG, “DRouter start load router table in drouter-table-thread”);
load(app);
}
}.start();
}
}
}
}
}

最终走到了RouterLoader的load方法来加载路由表到一个map中,仔细看它的引入路径是com.didi.drouter.loader.host.RouterLoader,是不存在于源码中的,因为它是编译的时候生成的,位置位于app/build/int

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值