滨海新区网站建设/泉州搜索推广
定义
- App StartUp是Google Jetpack新增的一个组件,该组件在App启动时提供了一个直接、高效的方式来初始化组件,同时开发者可以使用App Startup这个组件来简化启动顺序并且显示地设置初始化顺序,通过App Startup这个组件提供了一个ContentProvider来运行所有依赖项的初始化,避免第三方库单独通过ContentProvider进行初始化,从而提高了应用的启动速度,使用效果如下图所示:
- 图片来自 Husayn Hakeem
- 由上面两个图对比可见,App Startup提供了一个ContentProvider来运行所有依赖项的初始化工作
Why App Startup
- App 启动时会初始化一些逻辑,为了避免手动调用,使用ContentProvider进行初始化(例如WorkManager、LifeCycle以及第三方库)
- 在App冷启动阶段运行初始化的时候ContentProvider 的 onCreate()会先于Application的onCreate()方法执行,这样对多个ContentProvider会增加App的启动时间
- App Startup的出现就是为了解决上述问题
App Startup使用
- 首先添加dependency
dependencies { implementation "androidx.startup:startup-runtime:1.0.0-alpha01"
}
- 初始化
- 自动初始化
- 手动初始化
自动初始化
- LibaryA
class LibaryA : Initializer<WorkManager> {override fun create(context: Context): WorkManager {// 初始化LibaryAval configuration = Configuration.Builder().build()WorkManager.initialize(context, configuration)return WorkManager.getInstance(context)}override fun dependencies(): List<Class<out Initializer<*>>> {//LibaryA实例化不需要依赖其他return emptyList()}
}
- LibaryB
class LibaryB : Initializer<WorkManager> {override fun create(context: Context): WorkManager {// 初始化LibaryBreturn WorkManager.getInstance(context)}/*** 返回需要提前初始化的列表,同时设置App启动时的依赖库的依赖顺序*/override fun dependencies(): List<Class<out Initializer<*>>> {// LibaryB的实例化依赖LibaryAreturn mutableListOf(LibaryA::class.java)}
}
// LibaryB自动初始化
// AndroidManifest.xml文件中添加
<providerandroid:name="androidx.startup.InitializationProvider"android:authorities="${applicationId}.androidx-startup"android:exported="false"tools:node="merge"><!-- 自动初始化 --><meta-dataandroid:name="com.wjx.android.weather.common.startup.LibaryB"android:value="androidx.startup" />
</provider>
手动初始化
<providerandroid:name="androidx.startup.InitializationProvider"android:authorities="${applicationId}.androidx-startup"android:exported="false"tools:node="merge"><!-- 手动初始化 --><meta-dataandroid:name="com.wjx.android.weather.common.startup.LibaryB"android:value="androidx.startup"tools:node="remove"/>
</provider>
override fun create(context: Context): WorkManager {// 手动初始化LibaryA,已经手动初始化过的组件,在此调用不会执行初始化工作AppInitializer.getInstance(context).initializeComponent(LibaryA::class.java)return WorkManager.getInstance(context)
}
- 手动初始化(类似懒加载),在需要的组件的时候初始化进行调用,可以节省应用启动的时间,提高应用冷启动的速度
实践
- 项目(Weather)地址
class WeatherStartUp : Initializer<WorkManager> {override fun create(context: Context): WorkManager {val request =PeriodicWorkRequest.Builder(WeatherWorkManager::class.java, 15, TimeUnit.MINUTES).build()WorkManager.getInstance(context).enqueue(request)return WorkManager.getInstance(context)}override fun dependencies(): MutableList<Class<out Initializer<*>>> {return mutableListOf()}
}
- 手动初始化
<providerandroid:name="androidx.startup.InitializationProvider"android:authorities="${applicationId}.androidx-startup"android:exported="false"tools:node="merge"><!-- 手动初始化 --><meta-dataandroid:name="com.wjx.android.weather.common.startup.WeatherStartUp"android:value="androidx.startup"tools:node="remove"/>
</provider>
- 调用
AppInitializer.getInstance(instance).initializeComponent(WeatherStartUp::class.java)