3.Dagger2.38.1源码解析-ComponentProcessor注解规则 续

本文深入解析Dagger2的ComponentProcessor中关于@Inject、@AssistedInject及其相关注解的使用规则,包括构造函数、变量、方法的校验,以及@AssistedFactory、@Assisted等注解的规则。文章详细阐述了注解的限制、依赖检查和成员注入等方面,旨在帮助开发者更好地理解和使用Dagger2。

前言

可以加入575306647讨论dagger

这里是对Inject或InjectAssisted以及一些关联的注解进行规则校验,以及其他注解校验。

代码逻辑规则

具体代码体现出来的规则。

Inject和AssistedInject

整体了解

InjectProcessingStep类校验Inject和AssistedInject注解,InjectBindingRegistry对象是外部实例化后作为参数传递到当前InjectProcessingStep类。

InjectBindingRegistryImpl对象是用于实例化的InjectBindingRegistry,在InjectBindingRegistryImpl完成校验和Binding绑定对象的生成。

InjectProcessingStep类主要用于收集Inject或AssistedInject修饰的构造函数Inject修饰的变量或普通方法

  1. Inject或AssistedInject修饰的构造函数,对该构造函数校验并且生成ProvisionBinding对象,并且继续校验该构造函数所在父节点是否存在被Inject修饰的变量或方法,如果存在对该父节点进行校验并且生成MembersInjectionBinding对象;

  2. Inject修饰的变量或普通方法所在父节点校验,并且该父节点生成MembersInjectionBinding对象,并且对该父节点构造函数查看是否使用了Inject或AssistedInject注解,如果使用了,那么对该构造函数校验,并且生成ProvisionBinding对象。

  3. 注意以上的描述,我们需要知道,Inject既可以修饰变量或普通方法或构造函数,但是AssistedInject只可以用来修饰构造函数,详细情况下面具体规则。

Inject或AssistedInject修饰的构造函数

在validateConstructor类中校验,校验入口方法是validateConstructor;

对该构造函数校验,校验规则如下:

  1. 节点的构造函数不允许同时使用Inject注解和AssistedInject注解;

  2. 被Inject或AssistedInject修饰的构造函数不允许使用private修饰,也不能被Qualifier修饰的注解修饰;

  3. 被Inject或AssistedInject修饰的构造函数不能被Scope注解修饰的注解修饰;

  4. Inject或AssistedInject修饰的构造函数的参数不能是Produced< T>和Producer< T>类型,并且对参数和参数类型做依赖校验,规则如下:

  • 注:当前参数类型剥离RequestKind< T>类型得到T作为keyType(当然如果是RequestKind.INSTANCE,那么keyType就是参数类型)

  • (1)如果参数节点使用了@Assiste修饰,不进行下面的依赖校验;

  • (2)如果参数节点使用了Qualifier修饰的注解修饰,那么该类型注解不得超过1个;

  • (3)如果参数节点没有使用Qualifier修饰的注解修饰,那么keytype类型的构造函数不能使用AssistedInject修饰;

  • (4)如果参数节点没有使用Qualifier修饰的注解修饰,并且keyType节点使用了@AssistedFactory修饰,那么当前参数要么是T要么是Provider< T>,不能是Lazy< T>、Producer< T>或Produced< T>;

  • (5)keyType不能使用通配符;

  • (6)如果keyType是MembersInjector< T>(必须存在T)类型,那么对T进行成员注入校验:a.不能使用Qualifier注解修饰的注解修饰;b.T只能是类或接口,并且如果是泛型,那么泛型类型只能是类或接口或数组,数组只能是类或接口或数组,并且T不允许出现例如List类型(必须是List< T>类型);

  1. 被Inject或AssistedInject修饰的构造函数如果throws异常,那么异常一定要是RuntimeException或Error或两者子类;

  2. 使用了Inject或AssistedInject修饰的构造函数所在父节点不可以被private类使用,该构造函数所在父节点也不能使用abstract修饰,并且如果构造函数所在父节点是一个内部类,那么该内部类必须使用static修饰;

  3. 一个类最多只能有一个构造函数被Inject或AssitedInject修饰;

  4. 使用AssistedInject修饰的构造函数所在的父节点不能被使用Scope注解修饰的注解修饰;

  5. 使用Inject修饰的构造函数所在父节点最多只能有一个使用Scope注解修饰的注解修饰;

  6. 对当前Inject或AssisteInject修饰的构造函数的父节点中,如果存在Inject修饰的普通方法或变量,那么对当前父节点校验,参考Inject修饰的变量或普通方法。

Inject修饰的变量或普通方法

在validateConstructor类中校验,校验入口方法是validateMembersInjectionType;

Inject修饰的变量或普通方法校验的是当前Inject修饰的节点所在的父节点,校验规则如下:

  1. 对使用Inject修饰变量校验:
  • (1)Inject修饰的变量节点不能使用final修饰;也不要使用private和static修饰(可能警告可能报错);

  • (2)当前变量和变量类型做依赖校验:

  • 注:当前变量类型剥离RequestKind< T>类型得到T作为keyType(当然如果是RequestKind.INSTANCE,那么keyType就是变量类型)

  • ① 当前变量如果使用了Qulifiers注解修饰的注解,那么该类型的注解最多只能使用1个;

  • ② 如果变量节点没有使用Qualifier修饰的注解修饰,那么keytype类型的构造函数不能使用AssistedInject修饰;

  • ③ 如果变量节点没有使用Qualifier修饰的注解修饰,并且keyType节点使用了@AssistedFactory修饰,那么当前变量要么是T要么是Provider< T>,不能是Lazy< T>、Producer< T>或Produced< T>;

  • ④ keyType不能使用通配符;

  • ⑤ 如果keyType是MembersInjector< T>(必须存在T)类型,那么对T进行成员注入校验:a.T不能使用Qualifier注解修饰的注解修饰;b.T只能是类或接口,并且如果是泛型,那么泛型类型只能是类或接口或数组,数组只能是类或接口或数组,并且T不允许出现例如List类型(必须是List< T>类型)

  • ⑥ Inject修饰的变量节点不能是Produced< T>或Producer< T>类型;

  1. 对使用Inject修饰的普通方法校验:
  • (1)Inject修饰的普通方法必须是实现类,不能是abstract修饰的抽象类或接口方法;

  • (2)Inject修饰的普通方法不要使用private和static修饰(可能报错可能警告);

  • (3)Inject修饰的普通方法不能使用泛型类型,并且不能throws异常;

  • (4)Inject修饰的普通方法的参数合参数类型做依赖校验:

  • 注1:当前参数类型剥离RequestKind< T>类型得到T作为keyType(当然如果是RequestKind.INSTANCE,那么keyType就是参数类型);

  • 注2:如果参数使用了@Assisted修饰,不进行下面的依赖校验;

  • ① 当前参数如果使用了Qulifiers注解修饰的注解,那么该类型的注解最多只能使用1个;

  • ② 如果参数节点没有使用Qualifier修饰的注解修饰,那么keytype类型的构造函数不能使用AssistedInject修饰;

  • ③ 如果参数节点没有使用Qualifier修饰的注解修饰,并且keyType节点使用了@AssistedFactory修饰,那么当前参数要么是T要么是Provider< T>,不能是Lazy< T>、Producer< T>或Produced< T>;

  • ④ keyType不能使用通配符;

  • ⑤ 如果keyType是MembersInjector< T>(必须存在T)类型,那么对T进行成员注入校验:a.T不能使用Qualifier注解修饰的注解修饰;b.T只能是类或接口,并且如果是泛型,那么泛型类型只能是类或接口或数组,数组只能是类或接口或数组,并且T不允许出现例如List类型(必须是List< T>类型)

  • ⑥ Inject修饰的普通方法的参数类型不能是Produced< T>或Producer< T>类型;

  1. Inject修饰的节点所在父节点最好不要被private修饰(可能警告可能报错);并且Inject修饰的节点所在父节点不能是Kotlin Object或Kotlin Companion Object对象;

  2. 对当前使用Inject修饰的节点所在的父节点的非Object父级节点进行类型校验:

  • (1)对该节点中Inject修饰的变量或普通方法校验,从步骤1开始;

  • (2)对该节点使用Inject或AssistedInject修饰的构造函数校验,自行查看Inject或AssistedInject修饰的构造函数规则。

AssistedFactory

AssistedFactory修饰的节点中的方法仅仅针对abstract(接口除外)、非static、非private修饰的方法校验,

AssistedFactory注解使用规则如下:

  1. 使用AssistedFactory修饰的节点仅仅支持抽象类或接口;

  2. 如果AssistedFactory修饰的节点是内部类,那么必须使用static修饰;

  3. AssistedFactory修饰的节点必须有且仅有一个abstract、非static、非private的方法节点;

  4. AssistedFactory修饰的节点中的方法返回类型的构造函数必须使用@AssistedInject修饰;

  5. AssistedFactory修饰的节点中的方法不允许使用泛型;

  6. AssistedFactory修饰的节点中的唯一方法传递的参数 和 该方法返回类型中的构造函数使用@Assisted注解修饰的参数 保持一致。

Assisted

Assisted修饰的节点规则如下:

  1. Assisted只能修饰方法参数,并且仅仅满足一下条件:
  • (1)@Assisted修饰的参数,位于一个被@AssistedInject修饰的构造函数中;

  • (2)@Assisted修饰的参数所在的方法节点是所在父节点中唯一的一个abstract、非static、非private修饰的方法,并且该方法节点所在父节点使用@AssistedFactory注解修饰;

  • (3)@Assisted修饰的参数所在的方法 ,该方法命名包含"copy" ,该方法所在类是一个data类型的kotlin文件;

  1. @Assisted修饰的参数节点不能被Qualifier注解修饰的注解修饰;

  2. @AssistedInject修饰的构造函数或@AssistedFactory修饰的节点中的普通方法都不允许出现重复的@Assisted修饰的参数类型。

规则总结

根据代码总结出来的大致规则。

Inject和AssistedInject使用总结

  1. AssistedInject只能用于修饰构造函数,Inject可以用于修饰变量、构造函数或普通方法;

  2. 构造函数不能同时被Inject和AssistedInject修饰;

  3. Inject或AssistedInject修饰的构造函数不能使用private修饰,也不能使用Qualifier注解修饰的注解修饰,一个节点中只允许一个构造函数使用Inject或AssistedInject修饰;

  4. 依赖和成员注入对象:

  • (1)Inject或AssistedInject修饰的构造方法中的参数和参数类型作为依赖,如果参数类型是MembersInjector< T>,那么T作为成员注入对象;

  • (2)Inject修饰的普通方法中的参数和参数类型作为依赖,如果参数类型是MembersInjector< T>,那么T作为成员注入对象;

  • (3)Inject修饰的变量和变量类型作为依赖,如果变量类型是MembersInjector< T>,那么T作为成员注入对象;

  1. Inject修饰的变量不能使用final修饰,也不要使用private和static修饰;

  2. Inject修饰的普通方法必须是具体实现类;

AssistedFactory、AssistedInject和Assisted使用总结

  1. AssistedInject仅仅修饰构造函数;AssistedFactory只能修饰抽象类或接口;
  • (1)一个节点最多只能出现一个Inject或AssistedInject修饰的构造函数;

  • (2)AssistedFactory修饰的节点中有且仅有一个abstract、非private、非static修饰的方法;

  • (3)如果AssistedFactory修饰的是一个内部类,那么该内部类必须使用static修饰;

  1. Assisted只支持修饰参数,并且该参数位于①@AssistedInject修饰的构造方法中的参数 或 ②@AssistedFactory注解修饰的有且仅有的唯一方法的参数;并且同一个方法中不允许出现重复的Assisted修饰的参数;

  2. AssistedFactory修饰的节点中的唯一方法传递的参数 和 该方法返回类型中的构造函数使用@Assisted注解修饰的参数 保持一致。

其他注解

@IntoSet、@IntoMap和@ElementsIntoSet

  1. 以上三个注解在同一个方法上最多使用一个;

  2. 以上三个注解,必须在bindingMethod绑定方法上使用,并且只支持@Provides、@Produces或@Binds三种类型的bindingMethod方法;

  3. 如果使用了@ElementsIntoSet,那么当前bindingMethod方法返回类型必须是Set< T>;

  4. @IntoMap 和@MapKey修饰的注解一定是成对出现的。

@BindsInstance

@BindsInstance只能用来修饰方法和方法参数,并且在creator节点中不能用于修饰factoryMethod和buildMethod方法;

  1. 对@BindsInstance修饰的方法参数校验:
  • (1)当前使用@BindsInstance修饰的方法参数:

  • ①该参数不能使用FrameworkType架构类型:Provider,Lazy,MembersInjector,Produced,Producer;

  • ②该参数在没有使用Qualifier修饰的注解修饰情况下,参数类型的构造函数不能使用AssistedInject修饰并且参数类型不能使用AssistedFactory注解修饰;

  • ③参数类型只能是原始类型或数组或接口或类或变量类型;

  • (2)参数节点最多只能使用一个Qualifier修饰的注解修饰;

  • (3)参数节点不能使用Scope修饰的注解修饰;

  • (4)参数所在方法必须是abstract修饰的抽象方法或接口中的非default方法;

  • (5)@BindsInstance修饰的参数所在方法的返回类型,只能是一个类或接口(可以是泛型),不能是void、数组又或者原始类型。

  1. 对@BindsInstance修饰的方法进行校验:
  • (1)当前使用@BindsInstance修饰的方法校验:

  • 注:@BindsInstance修饰的方法有且仅有一个参数

  • ① 唯一参数的类型不能使用FrameworkType架构类型:Provider,Lazy,MembersInjector,Produced,Producer;

  • ② 唯一参数的类型的构造函数不能使用AssistedInject修饰并且该参数节点不能使用AssistedFactory注解修饰;

  • ③ 唯一的参数类型只能是原始类型或数组或接口或类或变量类型;

  • (2)@BindsInstance修饰的方法上最多只允许被一个Qualifier修饰的注解修饰;

  • (3)@BindsInstance修饰的方法不能使用Scope修饰的注解修饰;

  • (4)@BindsInstance修饰的方法必须使用abstract修饰或接口非default修饰的普通方法;

  • (5)@BindsInstance修饰的方法所在父节点不允许是module节点,也不允许是component节点,只能在creator节点中使用

MapKey

@MapKey只能用于修饰注解,对其校验规则如下:

  1. @MapKey修饰的注解必须有方法;

  2. @MapKey修饰的注解在MapKey.unwrapValue() = true的情况下,被修饰的注解类方法有且仅有一个,并且该方法的返回类型不可以是TypeKind.ARRAY数组;

  3. 如果MapKey.unwrapValue() = false,被修饰的注解类方法可以有多个,并且当前项目必须引用com.google.auto.value.AutoAnnotation;

  4. @MapKey修饰的注解最常用的是和@IntoMap作用于bindingMethod绑定方法,当前MapKey修饰的注解里面的方法值提供Map<K,V>中的K,bindingMethod上的绑定类型和返回类型决定V;

Qualifier

Qualifier修饰注解的注解,具体规则如下:

  1. 节点上只允许出现一个Qualifier修饰注解的注解;

  2. componentMethod方法只有在返回类型是subcomponent节点或subcomponent.creator节点情况下才允许使用Qualifier修饰的注解修饰;

  3. bindingMethod方法可以被Qualifier修饰的注解修饰;

  4. MembersInjector的成员注入T类型不允许使用Qualifier修饰的注解修饰;

  5. 被Inject或AssistedInject修饰的构造方法不允许使用Qualifier修饰的注解修饰,但是构造函数的参数可以;

  6. @Assisted修饰的参数节点不能被Qualifier注解修饰的注解修饰;

  7. 一个节点允许使用Qualifier修饰,那么当前节点类型(如果是方法,则表示方法返回类型)的构造函数可以使用AssistedInject修饰。

Scope

Scope修饰注解的注解,具体规则如下:

  1. module节点不允许使用Scope注解修饰的注解修饰;

  2. 针对bindingMethod方法,只有@Binds和@Provides修饰的bindingMethod支持使用Scope注解修饰的注解修饰,并且该bindingMethod方法只允许出现一个使用Scope注解修饰的注解修饰;

  3. 被Inject或AssistedInject修饰的构造函数不能被Scope注解修饰的注解修饰;

  4. 使用AssistedInject修饰的构造函数所在的父节点不能被使用Scope注解修饰的注解修饰; 使用Inject修饰的构造函数所在父节点最多只能有一个使用Scope注解修饰的注解修饰;

  5. @BindsInstance修饰的方法或方法参数都不可以使用Scope修饰的注解修饰。

依赖总结

  1. componentMethod方法无参并且返回类型不是subcomponent也不是subcomponent.creator,当前componentMethod方法节点方法返回类型做依赖校验;

  2. bindingMethod的方法参数节点参数类型做依赖校验;

  3. Inject或AssistedInject修饰的构造函数里面的参数节点参数类型做依赖校验;

  4. Inject修饰的变量节点变量类型做依赖校验;

  5. Inject修饰的普通方法的方法参数节点参数类型做依赖校验;

MembersInjector成员注入总结

  1. componentMethod方法无参并且返回类型不是subcomponent也不是subcomponent.creator,当前componentMethod方法作为依赖节点和方法返回类型做依赖校验后,如果方法返回类型是MembersInjector类型,对依赖节点和T做成员注入校验;

  2. componentMethod方法返回类型不是subcomponent节点也不是subcomponent.creator节点,并且有且仅有一个参数,该方法节点和方法参数类型做成员注入校验;

  3. bindingMethod的方法(方法参数节点作为依赖节点)参数做依赖校验,并且参数类型是MembersInjector< T>,对依赖节点和T做成员注入校验;

  4. Inject或AssistedInject修饰的构造函数里面的参数(该参数作为依赖节点)作为依赖,需要做依赖校验,如果参数类型是MembersInjector< T>,对依赖节点和T做成员注入校验;

  5. Inject修饰的变量作为依赖节点和变量类型做依赖校验,如果变量类型是MembersInjector< T>,对依赖节点和T做成员注入校验;

  6. Inject修饰的普通方法的参数作为依赖节点和参数类型做依赖校验,如果参数类型是MembersInjector< T>,对依赖节点和T做成员注入校验;

总结

注解逻辑规则已经基本说明完成(后面还会有),后面主要是生成对象,收集绑定,生成有向图,生成逻辑代码等。

<think>根据您的问题,您想知道在Android Studio 2024.3.1版本中,如何正确添加Hilt和ButterKnife的Gradle插件依赖。这两个插件依赖需要添加到项目根目录下的`build.gradle`(有时也叫做`build.gradle.kts`,如果是Kotlin脚本)文件中。 注意:在较新的Android Studio版本中,项目结构可能有两种构建脚本: 1. 项目根目录的`build.gradle`(或`build.gradle.kts`) - 用于配置整个项目的构建脚本和插件依赖。 2. 每个模块(如app模块)的`build.gradle`(或`build.gradle.kts`) - 用于配置特定模块的构建。 您提到的两个插件依赖: - `classpath &#39;com.google.dagger:hilt-android-gradle-plugin:2.41&#39;` 是Hilt的Gradle插件。 - `classpath &#39;com.jakewharton:butterknife-gradle-plugin:10.2.1&#39;` 是ButterKnife的Gradle插件。 这些插件依赖应该添加到项目根目录的`build.gradle`文件中的`buildscript.dependencies`块内。 以下是具体的步骤和代码: ### 步骤1:打开项目根目录的build.gradle文件 通常,项目根目录的`build.gradle`文件位于项目的顶层目录,与`settings.gradle`文件同级。 ### 步骤2:在buildscript块中添加依赖 在`buildscript`块中,确保有`repositories`(如google()和mavenCentral())和`dependencies`块。然后在`dependencies`块中添加这两个插件的classpath。 ### 示例代码(Groovy DSL - 即使用.gradle文件) ```groovy // 项目根目录的build.gradle文件 buildscript { repositories { google() mavenCentral() // 如果有其他仓库也可以添加 } dependencies { // 其他classpath,例如Android Gradle插件 classpath &#39;com.android.tools.build:gradle:8.3.2&#39; // 请使用与您项目匹配的版本 // 添加Hilt插件 classpath &#39;com.google.dagger:hilt-android-gradle-plugin:2.41&#39; // 添加ButterKnife插件 classpath &#39;com.jakewharton:butterknife-gradle-plugin:10.2.1&#39; // 注意:如果您使用Kotlin,还应该添加Kotlin插件 classpath "org.jetbrains.kotlin:kotlin-gradle-plugin:1.9.22" // 请使用与您项目匹配的Kotlin版本 } } // 所有模块的配置,通常放在allprojects块中 allprojects { repositories { google() mavenCentral() } } ``` ### 注意事项: 1. **版本兼容性**:请确保您使用的插件版本与您的项目其他依赖(如Android Gradle插件版本、Kotlin版本)兼容。特别是Hilt版本2.41可能不是最新,建议查看官方文档获取最新版本。 2. **ButterKnife的使用**:请注意,ButterKnife已经不再维护,官方推荐使用ViewBinding或DataBinding。如果您的项目是新项目,建议不要使用ButterKnife。 3. **应用插件**:在模块的`build.gradle`中,您还需要应用这些插件。例如,在app模块的`build.gradle`中,您需要添加: ```groovy // 对于Hilt plugins { id &#39;com.android.application&#39; id &#39;org.jetbrains.kotlin.android&#39; id &#39;kotlin-kapt&#39; id &#39;dagger.hilt.android.plugin&#39; // 应用Hilt插件 } ``` 对于ButterKnife,如果您仍要使用,在模块的`build.gradle`中应用: ```groovy apply plugin: &#39;com.jakewharton.butterknife&#39; ``` 或者使用plugins块(注意ButterKnife插件可能不支持新的plugins DSL,所以可能需要使用apply方式)。 4. **同步项目**:添加依赖后,同步项目(Sync Project with Gradle Files)。 ### 如果使用Kotlin DSL(build.gradle.kts) 如果您的项目使用Kotlin DSL(即`build.gradle.kts`文件),则添加方式如下: ```kotlin // 项目根目录的build.gradle.kts buildscript { repositories { google() mavenCentral() } dependencies { classpath("com.android.tools.build:gradle:8.3.2") // Android Gradle插件 classpath("com.google.dagger:hilt-android-gradle-plugin:2.41") // Hilt classpath("com.jakewharton:butterknife-gradle-plugin:10.2.1") // ButterKnife classpath("org.jetbrains.kotlin:kotlin-gradle-plugin:1.9.22") // Kotlin插件 } } allprojects { repositories { google() mavenCentral() } } ``` ### 最后 请根据您的项目实际情况调整版本号,特别是Android Gradle插件版本和Kotlin版本。您可以在[Android Gradle插件版本说明](https://developer.android.com/studio/releases/gradle-plugin)中查看推荐版本。 §§相关问题§§: 1. 如何在模块的build.gradle中应用Hilt和ButterKnife插件? 2. ButterKnife和ViewBinding有什么区别?为什么ButterKnife不再推荐使用? 3. Hilt依赖注入框架中,如何定义和注入一个依赖? 4. 如何解决Gradle同步时出现的插件版本冲突问题?</think>### 在 Android Studio 2024.3.1 中配置 Hilt 和 ButterKnife 在 Android Studio 2024.3.1 (Giraffe) 中,您需要将插件依赖添加到项目根目录的 `build.gradle` 文件中。以下是具体步骤: #### 1. 打开项目根目录的 `build.gradle` 文件 路径:`YourProject/build.gradle`(不是 app 模块的 build.gradle) #### 2. 添加依赖到 `buildscript.dependencies` 块 ```groovy // 项目根目录的 build.gradle buildscript { repositories { google() mavenCentral() } dependencies { // Android Gradle 插件(必须与你的 AS 版本兼容) classpath &#39;com.android.tools.build:gradle:8.3.2&#39; // 2024.3.1 推荐版本 // Hilt 插件 classpath &#39;com.google.dagger:hilt-android-gradle-plugin:2.48&#39; // 建议使用最新版 // ButterKnife 插件 classpath &#39;com.jakewharton:butterknife-gradle-plugin:10.2.1&#39; // 如果你使用 Kotlin classpath "org.jetbrains.kotlin:kotlin-gradle-plugin:1.9.22" // 使用与项目兼容的版本 } } allprojects { repositories { google() mavenCentral() } } ``` #### 3. 在 app 模块中应用插件 在 app 模块的 `build.gradle` 中: ```groovy // app/build.gradle plugins { id &#39;com.android.application&#39; id &#39;org.jetbrains.kotlin.android&#39; // 如果使用 Kotlin id &#39;kotlin-kapt&#39; // Kotlin 注解处理 id &#39;dagger.hilt.android.plugin&#39; // Hilt 插件 } apply plugin: &#39;com.jakewharton.butterknife&#39; // ButterKnife 插件 dependencies { // Hilt 依赖 implementation &#39;com.google.dagger:hilt-android:2.48&#39; kapt &#39;com.google.dagger:hilt-android-compiler:2.48&#39; // ButterKnife 依赖 implementation &#39;com.jakewharton:butterknife:10.2.1&#39; annotationProcessor &#39;com.jakewharton:butterknife-compiler:10.2.1&#39; } ``` ### 版本兼容性说明 | 组件 | 推荐版本 | 说明 | |------|----------|------| | Android Gradle Plugin | 8.3.2 | 与 AS 2024.3.1 完全兼容 | | Hilt | 2.48 | 最新稳定版 | | ButterKnife | 10.2.1 | 最终维护版本 | | Kotlin | 1.9.22 | AS 2024.3.1 内置版本 | ### 重要注意事项 1. **同步 Gradle**:修改后点击 "Sync Now" 2. **JDK 要求**:确保使用 JDK 17(File > Project Structure > SDK Location) 3. **ButterKnife 替代**:考虑迁移到 View Binding 或 Jetpack Compose ```gradle // 替代 ButterKnife 的 View Binding android { buildFeatures { viewBinding true } } ``` 4. **Hilt 应用类**:确保 Application 类使用 `@HiltAndroidApp` ```java @HiltAndroidApp public class MyApplication extends Application { // ... } ``` ### 常见问题解决 如果遇到 "Plugin [id: &#39;dagger.hilt.android.plugin&#39;] was not found": 1. 检查根 build.gradle 中的仓库配置(必须有 google() 和 mavenCentral()) 2. 确保网络可以访问 Maven 仓库 3. 尝试清理缓存:File > Invalidate Caches / Restart
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值