作者:newki
转载地址:https://juejin.cn/post/7099757089081262117
有人看了我的框架有疑问了,怎么依赖注入都是用的Hilt啊,都看不懂懂啦,那么复杂。你看Koin框架的依赖注入更简单的啦。
由此展开Hilt与Koin的对比。看看性能,代码各方面有没有谁比谁差。
一. Hilt的简单使用
了解Hilt得先了解它的前身Dagger2。这玩意太复杂了,学习成本陡峭,在MVP框架的时代(2017年左右)还能勉强应付,对应MVVM框架中ViewModel完全的水土不服。甚至是Google的官方都是一堆问题。
痛定思痛,谷歌是铁了心让Android开发者使用依赖注入啊,这不就搞了个Android中使用Dagger2的场景化框架Hilt。专门为Android开发而生,简化了构建过程,使用注解生成代码。很方便的使用Hilt。完美的的适配MVVM/MVI框架。最近更新的版本也兼容到Compose了。
谷歌为了开发者煞费苦心了。如何使用看下简单的示例代码:(后期会出详细的代码教程)
新版依赖,部分用法和老版本不同:
implementation 'com.google.dagger:hilt-android:2.38.1'
kapt 'com.google.dagger:hilt-android-compiler:2.38.1'
根目录的build.gradle定义Hilt插件
dependencies {
classpath 'com.android.tools.build:gradle:7.0.3'
classpath "org.jetbrains.kotlin:kotlin-gradle-plugin:$kotlin_version"
//路由
classpath 'com.alibaba:arouter-register:1.0.2'
//Hilt插件
classpath 'com.google.dagger:hilt-android-gradle-plugin:2.38.1'
运行模块需要导入插件(没办法APT代码生成就是这个流程)
apply plugin: 'dagger.hilt.android.plugin'
Application标注入口(Hilt中Android场景化的入口标识)
@HiltAndroidApp
class MyApplication : BaseApplication() {
}
开始写注入模块,全局的单例
@Module
@InstallIn(SingletonComponent::class)
class ApplicationModule {
@Provides
fun provideMyApplication(application: Application): MyApplication {
return application as MyApplication
}
//全局的Gson
@Provides
@Singleton
fun provideGson(): Gson {
return GsonFactory.getSingletonGson()
}
}
Activity级别的注入模块
@Module
@InstallIn(ActivityComponent::class)
class AuthDIModel {
//Activity级别同一个实例
@Provides
fun providePencil(): Pencil {
return Pencil()
}
@Provides
fun provideBook(pencil: Pencil): Book {
return Book(pencil)
}
}
ViewModel的注入
@HiltViewModel
class<