Kotlin + Flow 实现Android 应用初始化任务启动库
作者:ezy 发布时间:2023-05-23 12:58:28
标签:Kotlin,Flow,Android
目录
特性
引入依赖
使用
特性
Kotlin + Flow 实现的 Android 应用初始化任务启动库。
支持模块化,按模块加载任务
可指定工作进程名称,main 表示仅在主进程运行,all 表示在所有进程运行,默认值all
可指定任务仅在工作线程执行
可指定任务仅在调试模式执行
可指定任务在满足合规条件后执行
可指定任务优先级,决定同模块内无依赖同步任务的执行顺序
可指定依赖任务列表,能检测循环依赖
使用 Flow 调度任务
仅200多行代码,简单明了
有耗时统计
引入依赖
项目地址:github.com/czy1121/ini…
repositories {
maven { url "https://gitee.com/ezy/repo/raw/android_public/"}
}
dependencies {
implementation "me.reezy.init:init:0.9.0"
kapt "me.reezy.init:init-compiler:0.9.0"
// 使用 init-startup 代替 init 可以利用 Jetpack Startup 库自动初始化
// 无需在 Application.onCreate 调用 InitManager.init()
implementation "me.reezy.init:init-startup:0.9.0"
}
使用
在 AndroidManifest.xml 的 <application> 里添加模块
<meta-data android:name="modules" android:value="app" />
通过注解 @Init 和 InitTask 接口定义一个任务
@Init
class OneInit : InitTask {
override fun execute(app: Application) {
Log.e(TAG, "this is ${javaClass.simpleName} in ${Thread.currentThread().name}")
}
}
通过注解 @Init 的参数配置任务信息
@Target(AnnotationTarget.CLASS)
@Retention(AnnotationRetention.SOURCE)
annotation class Init(
val process: String = "all", // 指定工作进程名称,main 表示仅在主进程运行,all 表示在所有进程运行
val background: Boolean = false, // 是否在工作线程执行任务
val debugOnly: Boolean = false, // 是否仅在 DEBUG 模式执行任务
val compliance: Boolean = false, // 是否需要合规执行
val depends: Array<String> = [], // 依赖的任务列表
val priority: Short = 0 //
)
APT会按模块收集任务信息并生成任务加载器(InitLoader_$moduleName),任务加载器用于添加任务到TaskList
class Task(
val name: String, // APT收集的任务名称格式为 "$moduleName:${clazz.simpleName}"
val background: Boolean = false, // 是否在工作线程执行任务
val priority: Int = 0, // 进程运行的优先级,值小的先执行
val depends: Set<String> = setOf(), // 依赖的任务列表,同模块只需指定"${clazz.simpleName}",跨模块需要指定 "$moduleName:${clazz.simpleName}"
val block: () -> Unit = {}, // 待执行的任务
) {
val children: MutableSet<Task> = mutableSetOf() // 子任务列表
}
核心类
TaskList 负责持有和添加任务
TaskManager 负责调度任务,支持添加开关任务(没有业务仅作为开关,可手动触发完成,并偿试执行其子任务)
无依赖的异步任务,在子线程并行执行
无依赖的同步任务,在主线程顺序执行
有依赖的任务,确保无循环依赖,且被依赖的任务先执行
InitManager 负责找到各模块的任务加载器并开始启动初始化,它使用了一个合规开关来使相关任务在确定合规后执行
可以不使用 InitManager 收集任务
val taskList = TaskList(app).apply {
add("task1") {
}
add("task2", depends = setOf("t1")) {
}
add("task3", depends = setOf("task1")) {
}
}
val manager = TaskManager(taskList, setOf("t1"))
manager.start()
// ...
// 完成开关任务t1
manager.trigger("t1")
来源:https://juejin.cn/post/6938229049462358047
0
投稿
猜你喜欢
- 项目中需要实现一个状态显示的悬浮框,要求可以设置两种模式:拖动模式和不可拖动模式。实现效果图如下:实现步骤:1.首先要设置该悬浮框的基本属性
- Android中Property模块的键值设置Prop模块是保存少量的全局共享信息,其保存的数据具有信息量少,跨进程共享数据等特性;每一条信
- 在 C# 中,new 关键字可用作运算符、修饰符或约束。new 运算符 用于创建对象和调用构造函数。new 修饰符 用于向基类成员隐藏继承成
- 什么是不可变对象?String对象是不可变的,但这仅意味着你无法通过调用它的公有方法来改变它的值。众所周知, 在Java中, String类
- 示例代码:<%@ Page Language="C#" AutoEventWireup="true&qu
- 使用抽象类应该注意的几个要点:包含一个或者多个抽象方法的类必须被声明为抽象类. 将类声明为抽象类,不一定含有抽象方法.通常认为,在抽象类中不
- 我们在项目中都会遇到项目打包,可以通过assembly对我们的项目进行打包。针对打包构建jar包,本文不再叙述。具体可以参考maven插件a
- 实践过程效果代码public partial class GlorifyCheckBox : CheckBox {
- 这几天在项目里面发现我使用@Transactional注解事务之后,抛了异常居然不回滚。后来终于找到了原因。如果你也出现了这种情况,可以从下
- 1.介绍在SpringBoot的Web项目中,默认采用的是内置Tomcat,当然也可以配置支持内置的jetty,内置有什么好处呢? 1. 方
- 背景在我做WinForm开发的过程中,经常会遇到耗时操作或阻塞操作。他们会引发软件的卡顿甚至假死,严重影响软件的使用。因此,这类耗时或阻塞的
- 标题栏中的返回按钮在实际使用中用的比较多,今天就来讲讲我在项目开发中的使用经历,话不多说,还是直接上源码,上源码是最给力的。一、 编写自定义
- 本文实例为大家分享了Android自定义实现可滑动按钮的具体代码,供大家参考,具体内容如下实现逻辑1.创建一个类继承view类,实现里面的o
- C语言数据结构之二叉树的非递归后序遍历算法前言:前序、中序、后序的非递归遍历中,要数后序最为麻烦,如果只在栈中保留指向结点的指针,那是不够的
- 本文主要对SpringBoot2.x参数校验进行简单总结,其中SpringBoot使用的2.4.5版本。一、引入依赖<dependen
- 1:HttpHelper.javapublic class HttpHelper { //1:标准的Ja
- 1.前言以前没有使用mybatis,可以关闭自动提交,然后做sql操作,对操作进行catch捕获异常,如果没有异常则commit 提交 ,有
- 本文实例讲述了Android实现Service获取当前位置(GPS+基站)的方法。分享给大家供大家参考。具体如下:需求详情:1)、Servi
- 将自然语言编写的测试用例转换为可执行的测试,可以大大降低需求与开发之间的沟通成本,这是BDD(行为驱动开发)希望达到的效果。SpecFlow
- 使用 Spring 时,XML 和注解是使用得最多的两种配置方式,虽然是两种完全不同的配置方式,但对于 IOC 容器来说,两种方式的不同主要