ARouter初始化时,会调用LogisticsCenter.init(mContext, executor)
方法,该方法通过反射扫描包下指定的路径,获取编译时根据注解生成的类,然后通过反射将数据缓存到Warehouse
类对应的集合中。
为了解决ARouter初始化时,反射扫描包下的路径导致的耗时操作,ARouter提供了字节码插桩的方式。通过提供的插件在loadRouterMap
方法中处理数据,并将registerByPlugin置为true。
public synchronized static void init(Context context, ThreadPoolExecutor tpe) throws HandlerException {
loadRouterMap();
if (registerByPlugin) {
//字节码插桩处理
} else {
//反射处理
}
}
2. ARouter跳转
ARouter.getInstance().build(“/ar/ma2”)
.withInt(“age”,100)
.withString(“name”,“xiaoli”)
.navigation()
这是一个最标准的ARouter的跳转方式,当执行到build方法时,会根据路由的路径拆分出对应的group,创建一个Postcard
对象。Postcard中封装了对应基本数据类型和实现序列化的类的with方法,通过这些方法,可以方便的添加需要传递的参数,封装在Bundle中。当执行到navigation方法时,会按照下面的方法执行。
protected Object navigation(final Context context, final Postcard postcard, final int requestCode, final NavigationCallback callback) {
LogisticsCenter.completion(postcard);
if (!postcard.isGreenChannel()) {
interceptorService.doInterceptions(postcard, new InterceptorCallback() {
@Override
public void onContinue(Postcard postcard) {
_navigation(context, postcard, requestCode, callback);
}
@Override
public void onInterrupt(Throwable exception) {
if (null != callback) {