Hilt原理分析二(HIlt如何实现Application的依赖注入)

简介: HIlt如何实现Application的依赖注入

系列文章

在上一篇文章中,我们知道MyApplication添加了@HiltAndroidApp注解后,会生成四个文件

59e974d88da202e94a9e5098668ce80.png

这节就来分析一下这四个文件,了解一下这四个文件的关系及作用,先从Hilt_MyApplication分析,代码如下

b4e32db0a934a39601cf41bb31184c1.png

从Application的入口函数onCreate方法开始分析,可以看到代码很少,只有一句,Hilt_MyApplication类的其他方法也是被这句代码调用的,方法的调用顺序如下

4c4b8b77f01cd39890dfeb6ca8c95fd.png

Hilt_MyApplicationcomponentManager方法中创建了ApplicationComponentManager对象,然后调用了ApplicationComponentManager对象的generatedComponent方法,代码如下

3d4b3e2ee8316b3ee790925c7990db7.png

generatedComponent方法调用后,走到了这里

d97b9530aface9841283bb835d210db.png

这里就走到了生成的4个类的另外一个类DaggerMyApplication_HiltComponents_SingletonC里面。

DaggerMyApplication_HiltComponents_SingletonC方法分析

调用的方法时序如下图

b3b5c7c74ec136e08b7147cc140e2ad.png

至此,Hilt_MyApplication的onCreate方法的

f5cdb18bde8b2771b45170e1c75c8f2.png

红框的部分就分析完了,红框部分执行后返回DaggerMyApplication_HiltComponents_SingletonC对象,然后injectMyApplication方法将Application作为入参传入,injectMyApplication方法的代码如下

a8ac08d136f62f3a817a55974e3e288.png

这里只是一个空方法,看不出来什么,为了能更好的理解Hilt的原理,再在MyApplication类里面增加一些代码,如下

@HiltAndroidApp
class MyApplication : Application() {
    @Inject
    lateinit var applicationModel: ApplicationModel
    override fun onCreate() {
        super.onCreate()
        applicationModel.doSomething()
    }
}

ApplicationModel的代码如下

class ApplicationModel @Inject constructor() {
    fun doSomething() {
        Log.d("wizardev", "doSomething")
    }
}

MyApplication类中新增了成员变量并加了@Inject注解,然后在onCreate方法中直接调用doSometing方法,直接运行程序,打印的Log如下

27c040fe3cfff46fd227b7e5c98325d.png

可以发现,在MyApplication中并没有对applicationModel赋值,但是仍然可以直接调用doSometing方法,那么关于赋值的这部分毫无疑问是Hilt框架帮我们做的,Hilt是怎么做到的呢?仍然要从代码中获取答案。

Hilt是如何实现依赖注入的

直接看编译后代码的变化,如下图

6668b04eba3b964bb7e677e92f53632.png

可以看到编译后新增了两个类,从前文我们知道,MyApplication类没增加新增变量之前,DaggerMyApplication_HiltComponents_SingletonCinjectMyApplication方法是一个空方法,看下新增变量后的injectMyApplication方法,如下

78dda827c02ea2fce27214444747553.png

再看下injectMyApplication2方法,如下

528ceaa2853d5bd10f3b65f7273889e.png

可以发现,最终调用到了新生成的MyApplication_MembersInjector类的injectApplicationModel方法,injectApplicationModel方法的代码如下

058e0a4f7b1d592db0e067e11446569.png

这个方法就是对MyApplication成员变量applicationModel赋值的地方,可以发现这里并没有用到另外一个类—ApplicationModel_Factory就实现了依赖注入,那么还用这个类干嘛呢?因为会在其他地方用到,欲知详情,请看下一篇文章。



相关文章
|
7月前
|
Java Spring 容器
Spring注解开发,bean的作用范围及生命周期、Spring注解开发依赖注入
Spring注解开发,bean的作用范围及生命周期、Spring注解开发依赖注入
69 1
Spring注解开发,bean的作用范围及生命周期、Spring注解开发依赖注入
|
7月前
|
设计模式 算法 Java
【设计模式】springboot3项目整合模板方法深入理解设计模式之模板方法(Template Method)
【设计模式】springboot3项目整合模板方法深入理解设计模式之模板方法(Template Method)
|
Java 数据库 Android开发
使用Hilt完成依赖注入,让你的安卓代码层次有几层楼那么高(三)
使用Hilt完成依赖注入,让你的安卓代码层次有几层楼那么高(三)
236 0
|
Android开发
Dagger Hilt - ViewModel的依赖注入及实现原理
Dagger Hilt VIewModel 依赖注入的原理
505 0
|
设计模式 Java Spring
Spring框架核心源码分析(二)
@[TOC](目录) 由于 Spring 框架的源代码非常复杂,包含许多核心组件和模块,因此分析源代码并提供详细的代码片段将需要相当长的篇幅。尝试提供一些关于 Spring 框架核心组件的简要介绍和代码片段,以帮助您更好地理解 Spring 框架的实现原理。 # 1. BeanFactory BeanFactory 是 Spring 框架的核心组件之一,它是一个工厂设计模式的实现,用于创建和管理 Bean 对象。在 Spring 中,BeanFactory 负责管理 Bean 的创建、配置和管理,包括实例化 Bean 对象、配置 Bean 对象的属性、解决依赖关系等。 以下是一个简单的 Bea
|
Java Android开发 Kotlin
Hilt原理分析一(Hilt技术概览)
Hilt原理分析一(Hilt技术概览)
|
Android开发
使用Hilt完成依赖注入,让你的安卓代码层次有几层楼那么高(四)
使用Hilt完成依赖注入,让你的安卓代码层次有几层楼那么高(四)
250 0
|
Android开发 容器
使用Hilt完成依赖注入,让你的安卓代码层次有几层楼那么高(一)下
使用Hilt完成依赖注入,让你的安卓代码层次有几层楼那么高(一)
162 0
|
程序员 Android开发 容器
使用Hilt完成依赖注入,让你的安卓代码层次有几层楼那么高(一)上
使用Hilt完成依赖注入,让你的安卓代码层次有几层楼那么高(一)
99 0
|
Android开发 容器
使用Hilt完成依赖注入,让你的安卓代码层次有几层楼那么高(二)下
使用Hilt完成依赖注入,让你的安卓代码层次有几层楼那么高(二)
116 0

热门文章

最新文章