第三方Android

【学习】Jetpack新成员:依赖注入库Hilt

2021-05-13  本文已影响0人  Merbng
Hilt

前言

基于Dagger2Hilt以Android专属DI框架的身份继续完善了Jetpack的布局,本文将主要介绍Hilt的优点&缺点

定义

基于Dagger(Dagger2),专为Android App打造的依赖注入方案。

特点

它在保留Dagger2的编译时注入的性能优势前提下,简化了注解的使用,同时针对Android框架类进行了优化。

储备知识

在讲解Hilt前先来简单了解依赖注入的各个角色&流程

Hilt的优点

主要包括:

优点1:高度封装了框架类的注入

@HiltAndroidApp
class MyApplication :Application(){...}
@AndroidEntryPoint
open class BaseActivity():AppCompatActivity(){...}

优点2:绑定生命周期

@InstallIn注解可以告知Hilt每个模块将用在或绑定哪个Android类中。比如指定的value为ApplicationComponent的话将表明该模块在整个应用周期内只会实例化一份,即单例。其他的还有绑定Activity生命周期的ActivityComponent。

@Module
@InstallIn(ApplicationComponent::class)
class NetworkModule{...}

优点3:预设作用域

@Singleton@ActivityRetainedScoped等注解用以声明该注入的作用范围。比如Activity因为Configuration Change重绘了但@ActivityRetainedScoped注解的依赖并不会重新创建。

@ActivityRetainedScoped
class MovieAdapter @Inject constructor(){...}

@AndroidEntryPoint
class DemoActivity :AppCompatActivity(){
    @Inject lateinit var movieAdapter:MovieAdapter
    ...
}

优点4:注入Context

通过@ApplicationContext@ActivityContext注解等可以快速注入Context实例,省的我们自己提供Context的实现

class MovieAdapter @Inject constructor(@ActivityContext private val context:Context):RecycleView.Adapter<RecycleView.ViewHolder>(){...}

优点5:Jetpack组件的支持

Hilt实现了一些扩展帮助我们注入ViewModel和WorkManager的依赖,比如:@ViewModelInject注解就可以告知Hilt此处需要注入ViewModel实例。

class MovieViewModel @ViewModelInject constructor(private val repository:Repository,var movieAdapter:MoveAdapter):ViewModel(){...}

Hilt的缺点

主要包括:

  1. @AndroidEntryPoint的限制
  2. Android框架类的注入限制
  3. 生命周期限制
  4. ViewModel注入限制

缺点1:@AndroidEntryPoint的限制

缺点2:Android框架类的注入限制

缺点3:生命周期的限制

使用@ViewModelInject向ViewModel注入依赖时需要注意:

总结

相较于Dagger2,Hilt确实存在许多优点,但由于其同时也带来了一些天生的劣势,在实际应用中,需要根据实际需要做出抉择:小而美的Hilt亦或者大而强的Dagger2

官方文档

https://developer.android.google.cn/training/dependency-injection/hilt-android

本文来自读者虾米君投稿,其公众号:TechMerger
查看原文

上一篇下一篇

猜你喜欢

热点阅读