手把手教你搭建android模块化项目框架(十一)——使用AutoService优化Router

今天周六~水一天。

之前的路由篇我们大概讲了一个简单的模块化路由的实现思路,但是用起来比较麻烦,每次还需要手动指定path,手动注册到core_router模块,那么今天,我们就来优化一个吧~

要优化路由,首先我们得了解一下java的spi,即Service Provider Interface,大致意思就是通过接口反向找到实现类(们),然后动态创建实现类使用,达到解耦的目的,也就是说,我们只要知道接口,并且实现类进行了SPI的配置,那就可以进行反向查询和创建啦~

由于SPI使用每次也需要配置,在META-INF/services中配置对应文件,google开发了一款工具用来协助开发者自动创建配置文件,即autoservice

至于原理什么的,我向来懒得讲,如果想要深入研究,可以直接看原理,直接看效果。

首先我们引入autoservice

     //autoservice:"com.google.auto.service:auto-service:1.1.1"
    implementation rootProject.ext.deps.autoservice
    这里注意需要使用Kapt
    kapt rootProject.ext.deps.autoservice

然后在service_lottery模块中创建我们的路由接口类,这里我们使用与service_lottery中一样的类做测试。

@AutoService(LotteryServiceAuto::class)
class LotteryServiceAutoProvider : LotteryServiceAuto {
    override fun launchLotteriesAct(context: Context) {
        context.startActivity(Intent(context, LotteriesAct::class.java))
    }

    override fun init(app: Context) {

    }
}

之后我们在feature_lottery模块中创建实现类

@AutoService(LotteryServiceAuto::class)
class LotteryServiceAutoProvider : LotteryServiceAuto {
    override fun launchLotteriesAct(context: Context) {
        context.startActivity(Intent(context, LotteriesAct::class.java))
    }

    override fun init(app: Context) {
          由于是自动注册,这里也不需要注册到core_router模块了
    }
}

这样我们就创建好一个能够支持自动反向查询的实现类了~

此时我们运行项目,就会发现系统已经自动帮我们生成好了配置类build/intermediates/java_res/debug/out/META-INF/servicies/xxxxxx

下面是具体应用,一样在我们的lotteryProxy类中进行代理

object LotteryProxy {
    这是原来的手动查询实现类方式
    private val provider by lazy {
        Router.getProvider(LotteryServicePath.LOTTERY_SERVICE_PATH_CODE) as LotteryService
    }

    private val providerAuto by lazy {
        这是使用autoservice自动查询实现类的方式
        这里需要注意,如果有多个实现类,则list会返回多个结果,但是我们路由通常只会有一个实现类,所以取第0个即可。
        ServiceLoader.load(LotteryServiceAuto::class.java).toList()[0]
    }
    
    fun launchLotteriesAct(context: Context) {
        provider.launchLotteriesAct(context)
    }

    与之前一样的使用方式
    fun launchLotteriesActAuto(context: Context) {
        providerAuto.launchLotteriesAct(context)
    }
}
    override fun setup() {
        super.setup()
        与之前一样的使用方式
        LotteryProxy.launchLotteriesActAuto(this)
    }

如此,我们便完成了使用autoservice自动注册路由啦~

完整项目地址:传送门

  • 3
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
Java中的autoservice注解是一种用于服务发现的机制,它能够自动将服务的实现类注册到指定的配置文件中,一般是META-INF/services目录下的文件。 然而,的确有一些情况下autoservice注解无法生成META-INF文件。这可能是由于以下几种原因导致的: 1. 编译问题:可能是由于编译配置的问题,导致编译器无法正确处理autoservice注解。这种情况下,我们可以尝试检查编译器的配置,或者使用其他IDE或编译工具进行尝试。 2. 库或框架限制:有些库或框架可能不支持autoservice注解,或者在使用autoservice注解时会有特殊的要求。我们可以查看相关库或框架的文档,了解其对autoservice注解的支持情况,或者尝试其他方式实现服务发现。 3. 配置文件缺失或错误:autoservice注解生成META-INF文件的前提是META-INF目录存在,并且配置文件的名称和路径正确。如果自动生成的META-INF文件不存在,或者文件名或路径有误,就无法实现服务发现。我们需要检查项目的文件结构,确认META-INF目录是否存在,并且配置文件的名称和路径是否正确。 总之,虽然autoservice注解通常可以自动将服务实现类注册到META-INF文件中,但在某些情况下可能会遇到无法生成META-INF文件的问题。我们需要仔细检查编译配置、库或框架限制,以及配置文件是否正确等因素,以找出问题所在,并采取相应的解决方案。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值