欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  移动技术

Kotlin + Flow 实现Android 应用初始化任务启动库

程序员文章站 2022-04-17 13:24:44
特性kotlin + flow 实现的 android 应用初始化任务启动库。 支持模块化,按模块加载任务 可指定工作进程名称,main 表示仅在主进程运行,all 表示在所有进程运行,默认值al...

特性

kotlin + flow 实现的 android 应用初始化任务启动库。

  • 支持模块化,按模块加载任务
  • 可指定工作进程名称,main 表示仅在主进程运行,all 表示在所有进程运行,默认值all
  • 可指定任务仅在工作线程执行
  • 可指定任务仅在调试模式执行
  • 可指定任务在满足合规条件后执行
  • 可指定任务优先级,决定同模块内无依赖同步任务的执行顺序
  • 可指定依赖任务列表,能检测循环依赖
  • 使用 flow 调度任务
  • 仅200多行代码,简单明了
  • 有耗时统计

引入依赖

项目地址:

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")

以上就是kotlin + flow 实现android 应用初始化任务启动库的详细内容,更多关于实现android 应用初始化任务启动库的资料请关注其它相关文章!