赞
踩
.build(PR.navi.navi)
.navigation();
而Activity
则不需要,它会立即显示
ARouter.getInstance()
.build(PR.navi.navi)
//还可以设置参数,ARouter会帮你存在Bundle中
.withString(“pathId”,UUID.randomUUID().toString())
//Activity 或 Context
.navigation(this);
navi
模块是典型的业务逻辑模块,这里你可导入一些只有这个模块才会使用的专属第三方SDK,比如我在navi
模块中使用了高德地图
的SDK
,其他模块只需要我这个模块的地图功能,但它不应该知道我到底使用的是高德
还是百度
还是腾讯
地图,这就提高了封装性,在未来改变此模块的具体实现时,代价也会小得多.
ARouter
实现了module
间的路由操作,同时也实现了拦截器的功能,拦截器是一种AOP
(面向切面编程),比较经典的使用场景就是处理页面登录与否的问题.拦截器会在跳转之间执行,多个拦截器会按优先级顺序依次执行.通过实现IInterceptor
接口并标注@Interceptor
注解,这样一来,这个拦截器就被注册到ARouter
当中了.
process
方法会传入Postcard
和InterceptorCallback
,Postcard
携带此次路由的关键信息,而InterceptorCallback
则用于处理此次拦截,调用onContinue
则放行,又或者调用onInterrupt
抛出自定义异常.
拦截器会在ARouter
初始化的时候进行异步
(不在主线程)初始化,如果第一次路由发生时,还有拦截器没有初始化完毕,那么ARouter
会等待该拦截器初始化完毕才进行路由.
@Interceptor(priority = 8)
public class TestInterceptor implements IInterceptor {
@Override
public void process(Postcard postcard, InterceptorCallback callback) {
callback.onContinue(postcard); // 处理完成,交还控制权
// callback.onInterrupt(new RuntimeException(“我觉得有点异常”));
// 觉得有问题,中断路由流程
// 以上两种至少需要调用其中一种,否则不会继续路由
}
@Override
public void init(Context context) {
// 拦截器的初始化,会在ARouter初始化的时候调用该方法,仅会调用一次
}
}
当页面未找到时,我们可以定义一种降级策略来让程序继续运行,此时我们需要实现DegradeService
接口,并用@Route
(必须)标注,然后它会在全局范围内生效,你可以在onLost
回调中自定义降级逻辑.
@Route(path = “/xxx/xxx”)
public class DegradeServiceImpl implements DegradeService {
@Override
public void onLost(Context context, Postcard postcard) {
// do something.
}
@Override
public void init(Context context) {
}
}
有时候页面我们需要将path
其重定向别的path
,这时我们可以实现PathReplaceService
接口,并用@Route
(必须)标注,然后它会在全局范围内生效.所以若没有重定向需求记得返回原path
@Route(path = “/xxx/xxx”)
public class PathReplaceServiceImpl implements PathReplaceService {
String forString(String path) {
return path; // 按照一定的规则处理之后返回处理后的结果
}
Uri forUri(Uri uri) {
return url; // 按照一定的规则处理之后返回处理后的结果
}
@Override
public void init(Context context) {
}
}
以上上三种接口中的init
方法,只有拦截器的调用时间是特殊的,其他两种,都是在第一次使用时才会进行初始化.
有的时候我们可能需要的不是另外一个模块的页面,而是它提供的服务(MVC中的Model层),这时这时我们需要为自己想要的服务编写一个接口,并让他实现IProvider
接口,然后把它放到common
模块中, 但是接口的实现依然放在非common
的具体的模块中,比如common
模块的TTSService
和ai
模块的TTSServiceImpl
.
这种做法被称为接口下沉
,其实它并不是严格符合解耦
思想的,但是它非常有用,就像你使用了ARouter
,但没人规定你就不能用startActivity
了一样,框架最终的目的还是为了方便我们编码的,而不是为了给我们添堵,更何况最终结果各模块依然是松散耦合的.
服务的初始化时机也是在第一次使用的时候.我们在common
模块中声明TTSService
接口:
public interface TTSService extends IProvider
{
void send(String text);
void stop();
}
并在ai
模块中实现它并使用@Route
注解标注
@Route(path = PR.ai.tts_service)
public class TTSServiceImpl implements TTSService
{
//省略…
}
这样我们就能在其他模块使用该服务了
TTSService ttsService = (TTSService) ARouter.getInstance()
.build(PR.ai.tts_service)
.navigation()
有些第三方SDK
初始化是必须要在Application
的onCreate
中进行初始化的,但是如果我们编写独立于host
的module
时,要怎么初始化它们呢?
ARouter
并没有提供官方的解决方案,但是经过我的实践,我们可以通过声明ContentProvider
并在模块内AndroidManifest
中注册它来实现初始化功能.
//java
public class ModuleLoader extends ContentProvider
{
@Override
public boolean onCreate()
{
Context context = getContext();
//TODO
return true;
}
//…
}
//AndroidManifest
ContentProvider#onCreate
在Application#attachBaseContext
调用之后Application#onCreate
调用之前执行,并且可以通过getContext
拿到Application
的Context
.这样就解决了部分第三方SDK
初始化的问题.
简单概括起来其实也就是两个知识点:
APT
注解处理器通过注解生成RouteMeta
元数据到指定包下Dex
指定包下class
,加载并缓存路由表,然后在navigation
是对path
映射到的不同类型尽可能地抽象出同一套接口如果还想深入理解ARouter
,可能就需要去读源码了.
ARouter
目前暂时不支持多进程开发,这是我觉得比较遗憾的,希望未来能够支持吧.
ARouter
的介绍就到此为止了,如果还想了解ARouter
的依赖注入功能请移步Github.
自我介绍一下,小编13年上海交大毕业,曾经在小公司待过,也去过华为、OPPO等大厂,18年进入阿里一直到现在。
深知大多数初中级安卓工程师,想要提升技能,往往是自己摸索成长,但自己不成体系的自学效果低效又漫长,而且极易碰到天花板技术停滞不前!
因此收集整理了一份《2024年最新Android移动开发全套学习资料》送给大家,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友,同时减轻大家的负担。
由于文件比较大,这里只是将部分目录截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频
如果你觉得这些内容对你有帮助,可以添加下面V无偿领取!(备注Android)
架构师必须具备抽象思维和分析的能力,这是你进行系统分析和系统分解的基本素质。只有具备这样的能力,架构师才能看清系统的整体,掌控全局,这也是架构师大局观的形成基础。 你如何具备这种能力呢?一是来自于经验,二是来自于学习。
架构师不仅要具备在问题领域上的经验,也需要具备在软件工程领域内的经验。也就是说,架构师必须能够准确得理解需求,然后用软件工程的思想,把需求转化和分解成可用计算机语言实现的程度。经验的积累是需要一个时间过程的,这个过程谁也帮不了你,是需要你去经历的。
但是,如果你有意识地去培养,不断吸取前人的经验的话,还是可以缩短这个周期的。这也是我整理架构师进阶此系列的始动力之一。
《设计思想解读开源框架》
片转存中…(img-NugeBayB-1710823810132)]
《360°全方面性能优化》
[外链图片转存中…(img-3eT0SRDy-1710823810132)]
本文在开源项目:【GitHub 】中已收录,里面包含不同方向的自学编程路线、面试题集合/面经、及系列技术文章等,资源持续更新中…
Copyright © 2003-2013 www.wpsshop.cn 版权所有,并保留所有权利。