Ошибка впрыска поля рукояти «свойство не инициализировано»?

#android #kotlin #dependency-injection #dagger-hilt

Вопрос:

Я просто следовал официальным документам Hilt и попытался реализовать простую инъекцию поля, вот основное действие:

 import androidx.appcompat.app.AppCompatActivity
import android.os.Bundle
import dagger.hilt.EntryPoint
import dagger.hilt.android.AndroidEntryPoint
import javax.inject.Inject

@AndroidEntryPoint
class MainActivity : AppCompatActivity() {

    //field Injection
    @Inject lateinit var analytics: AnalyticsAdapter

    override fun onCreate(savedInstanceState: Bundle?) {
        super.onCreate(savedInstanceState)
        setContentView(R.layout.activity_main)

        println(analytics.doAThing())
    }
}

class AnalyticsAdapter @Inject constructor() {
    fun doAThing(): String{
        return "Hello"
    }
}
 

У меня также есть класс приложения, который объявлен в моем манифесте:

 @HiltAndroidApp
class MyApplication: Application() {

}
 

Вот ошибка, которую он выдает:

 2021-07-23 01:24:11.686 32325-32325/com.example.hilt E/AndroidRuntime: FATAL EXCEPTION: main
    Process: com.example.hilt, PID: 32325
    java.lang.RuntimeException: Unable to start activity ComponentInfo{com.example.hilt/com.example.hilt.MainActivity}: kotlin.UninitializedPropertyAccessException: lateinit property analytics has not been initialized
        at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:3449)
        at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:3601)
        at android.app.servertransaction.LaunchActivityItem.execute(LaunchActivityItem.java:85)
        at android.app.servertransaction.TransactionExecutor.executeCallbacks(TransactionExecutor.java:135)
        at android.app.servertransaction.TransactionExecutor.execute(TransactionExecutor.java:95)
        at android.app.ActivityThread$H.handleMessage(ActivityThread.java:2066)
        at android.os.Handler.dispatchMessage(Handler.java:106)
        at android.os.Looper.loop(Looper.java:223)
        at android.app.ActivityThread.main(ActivityThread.java:7656)
        at java.lang.reflect.Method.invoke(Native Method)
        at com.android.internal.os.RuntimeInit$MethodAndArgsCaller.run(RuntimeInit.java:592)
        at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:947)
     Caused by: kotlin.UninitializedPropertyAccessException: lateinit property analytics has not been initialized
        at com.example.hilt.MainActivity.getAnalytics(MainActivity.kt:13)
        at com.example.hilt.MainActivity.onCreate(MainActivity.kt:19)
        at android.app.Activity.performCreate(Activity.java:8000)
        at android.app.Activity.performCreate(Activity.java:7984)
        at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1309)
        at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:3422)
        at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:3601) 
        at android.app.servertransaction.LaunchActivityItem.execute(LaunchActivityItem.java:85) 
        at android.app.servertransaction.TransactionExecutor.executeCallbacks(TransactionExecutor.java:135) 
        at android.app.servertransaction.TransactionExecutor.execute(TransactionExecutor.java:95) 
        at android.app.ActivityThread$H.handleMessage(ActivityThread.java:2066) 
        at android.os.Handler.dispatchMessage(Handler.java:106) 
        at android.os.Looper.loop(Looper.java:223) 
        at android.app.ActivityThread.main(ActivityThread.java:7656) 
        at java.lang.reflect.Method.invoke(Native Method) 
        at com.android.internal.os.RuntimeInit$MethodAndArgsCaller.run(RuntimeInit.java:592) 
        at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:947) 
 

Используя версию 2.38 эфеса.

Почему самые простые вещи не работают -.-

Комментарии:

1. Это может произойти, если вы промахнетесь @AndroidEntryPoint . Попробуйте остановить демона gradle и перестроить свой проект. Ваш код отлично работает для меня.

2. Попробуйте Build -> Clean Project , и тогда Build -> Rebuild Project ваш код будет выглядеть хорошо. Какова ваша версия Android Studio?

Ответ №1:

Через два часа я понял, что в файле build.gradle вашего проекта должна быть более низкая версия hilt в строке пути к классу:

Понижение с версии 2.38 до 2.28-альфа:

 classpath 'com.google.dagger:hilt-android-gradle-plugin:2.28-alpha'
 

Затем в файле сборки приложения.gradle продолжайте использовать версию 2.38:

 implementation "com.google.dagger:hilt-android:2.38"
kapt "com.google.dagger:hilt-android-compiler:2.38"
 

после понижения с 2,38 до 2,28-альфа в файле app build.gradle вам необходимо очистить кэш приложения на вашем устройстве, иначе оно все равно выйдет из строя.

Добро пожаловать в родную разработку Android, увлекательный опыт для всей семьи