# EasyLaunch
**Repository Path**: lotee/EasyLaunch
## Basic Information
- **Project Name**: EasyLaunch
- **Description**: No description available
- **Primary Language**: Unknown
- **License**: Not specified
- **Default Branch**: main
- **Homepage**: None
- **GVP Project**: No
## Statistics
- **Stars**: 0
- **Forks**: 0
- **Created**: 2025-10-11
- **Last Updated**: 2025-10-22
## Categories & Tags
**Categories**: Uncategorized
**Tags**: None
## README
# EasyLaunch
[](https://jitpack.io/#aidaole/EasyLaunch)
这是一个Android的启动开源框架, 用于在启动过程中将任务并行, 达到优化启动速度的目的.
框架特点:
1. 使用有向无环图配置任务依赖关系, 并支持检查当前任务是否成环
2. 支持main线程, 子线程同步初始化
3. 使用协程实现, 轻量级
4. 支持任务依赖的延迟解析,可以任意顺序添加任务
5. 支持任务完成监听,可以在特定任务完成后执行特定操作
## 执行效果
如项目中app的配置方案执行:
TaskA (执行递归fibonacci(40)模拟阻塞耗时操作), 异步, 无依赖
TaskB (执行Thread.sleep(300)), 异步, 无依赖
TaskC (执行delay(200)), 异步, 依赖B
TaskD (执行delay(100)), 同步主线程, 依赖 A, C
可以看到日志后方总结:
所有任务总时长是 1343, 但是实际执行时长是 1051. 因为任务 A,B 时并行执行的
```logcatfilter
启动任务已添加并开始执行
Application.onCreate() 继续执行
开始执行启动任务
开始执行任务: TaskA
开始执行任务: TaskB
TaskA 开始执行
TaskB 开始执行
任务执行完成: TaskB, 执行时长: 302ms, 开始总时长: 310ms
MainActivity onCreate:
任务执行完成: TaskA, 执行时长: 739ms, 开始总时长: 746ms
开始执行任务: TaskC
TaskC 开始执行
任务执行完成: TaskC, 执行时长: 201ms, 开始总时长: 948ms
开始执行任务: TaskD
TaskD 开始执行(主线程)
任务执行完成: TaskD, 执行时长: 101ms, 开始总时长: 1050ms
======== 任务执行时间统计 ========
所有任务合并执行时长: 1051ms
所有任务总时长: 1343ms
各任务执行时间:
1. TaskA: 739ms (55.0%)
2. TaskB: 302ms (22.5%)
3. TaskC: 201ms (15.0%)
4. TaskD: 101ms (7.5%)
================================
所有启动任务执行完成
```
## 使用方法
### 1. 添加依赖
在项目的根目录的build.gradle中添加JitPack仓库:
```groovy
allprojects {
repositories {
// ...
maven { url 'https://jitpack.io' }
}
}
```
在应用模块的build.gradle中添加依赖:
```groovy
dependencies {
implementation 'com.github.aidaole:EasyLaunch:[最新版本]'
}
```
### 2. 创建启动任务
创建启动任务需要实现`Task`接口:
```kotlin
class YourTask : Task {
// 任务名称
override val name: String
get() = "YourTask"
// 任务依赖,表示当前任务依赖的其他任务
override val dependencies: List>
get() = listOf(OtherTask::class.java)
// 是否是异步任务
override val isAsync: Boolean
get() = true
// 任务执行方法
override suspend fun execute() {
// 在此处实现任务的具体逻辑
}
}
```
### 3. 在Application中初始化
在Application的onCreate方法中初始化EasyLaunch:
```kotlin
class YourApplication : Application() {
override fun onCreate() {
super.onCreate()
// 初始化EasyLaunch
EasyLaunch.getInstance().init(this)
// 添加任务 - 可以任意顺序添加
EasyLaunch.getInstance()
.addTask(TaskD()) // 依赖TaskB和TaskC
.addTask(TaskB()) // 依赖TaskA
.addTask(TaskC()) // 依赖TaskA
.addTask(TaskA()) // 没有依赖
.start()
}
}
```
### 4. 等待任务完成
如果需要等待某些任务完成后再执行某些操作,可以使用任务完成监听:
```kotlin
// 监听单个任务完成
EasyLaunch.getInstance()
.addTaskCompletedListener(TaskB::class.java) {
// 当TaskB完成时执行
Log.d("Sample", "TaskB已完成,可以执行特定操作")
}
.start()
// 监听多个任务完成
EasyLaunch.getInstance()
.addTasksCompletedListener(listOf(TaskB::class.java, TaskC::class.java)) {
// 当TaskB和TaskC都完成时执行
Log.d("Sample", "TaskB和TaskC都已完成,可以执行特定操作")
}
.start()
// 监听所有任务完成
EasyLaunch.getInstance()
.addAllTasksCompletedListener {
// 当所有任务完成时执行
Log.d("Sample", "所有任务已完成,可以跳转到主界面")
startActivity(Intent(this, MainActivity::class.java))
finish()
}
.start()
```
更多详细信息请查看 [EasyLaunch模块README](easylaunch/README.md)。