代码之家  ›  专栏  ›  技术社区  ›  codejockie

java.lang.IollegalStateException:CompositionLocal LocalLifecycleOwner不存在

  •  1
  • codejockie  · 技术社区  · 10 月前

    我得到一个 java.lang.IllegalStateException: CompositionLocal LocalLifecycleOwner 当我 collectAsState() collectAsStateWithLifecycle() 。我不知道怎么了。这以前是有效的,但由于我进行了切换和一些依赖项更新,它停止了工作。错误如下:

    java.lang.IllegalStateException: CompositionLocal LocalLifecycleOwner not present
    at androidx.lifecycle.compose.LocalLifecycleOwnerKt$LocalLifecycleOwner$1.invoke(LocalLifecycleOwner.kt:26)
    at androidx.lifecycle.compose.LocalLifecycleOwnerKt$LocalLifecycleOwner$1.invoke(LocalLifecycleOwner.kt:25)
    at kotlin.SynchronizedLazyImpl.getValue(LazyJVM.kt:74)
    at androidx.compose.runtime.LazyValueHolder.getCurrent(ValueHolders.kt:29)
    at androidx.compose.runtime.LazyValueHolder.getValue(ValueHolders.kt:31)
    at androidx.compose.runtime.CompositionLocalMapKt.read(CompositionLocalMap.kt:90)
    at androidx.compose.runtime.ComposerImpl.consume(Composer.kt:2135)
    at androidx.lifecycle.compose.FlowExtKt.collectAsStateWithLifecycle(FlowExt.kt:182)
    at com.codejockie.wani.MainActivity$onCreate$1.invoke(MainActivity.kt:47)
    at com.codejockie.wani.MainActivity$onCreate$1.invoke(MainActivity.kt:45)
    at androidx.compose.runtime.internal.ComposableLambdaImpl.invoke(ComposableLambda.jvm.kt:109)
    at androidx.compose.runtime.internal.ComposableLambdaImpl.invoke(ComposableLambda.jvm.kt:35)
    at androidx.compose.ui.platform.ComposeView.Content(ComposeView.android.kt:428)
    at androidx.compose.ui.platform.AbstractComposeView$ensureCompositionCreated$1.invoke(ComposeView.android.kt:252)
    at androidx.compose.ui.platform.AbstractComposeView$ensureCompositionCreated$1.invoke(ComposeView.android.kt:251)
    at androidx.compose.runtime.internal.ComposableLambdaImpl.invoke(ComposableLambda.jvm.kt:109)
    at androidx.compose.runtime.internal.ComposableLambdaImpl.invoke(ComposableLambda.jvm.kt:35)
    at androidx.compose.runtime.CompositionLocalKt.CompositionLocalProvider(CompositionLocal.kt:228)
    at androidx.compose.ui.platform.CompositionLocalsKt.ProvideCommonCompositionLocals(CompositionLocals.kt:186)
    at androidx.compose.ui.platform.AndroidCompositionLocals_androidKt$ProvideAndroidCompositionLocals$3.invoke(AndroidCompositionLocals.android.kt:119)
    at androidx.compose.ui.platform.AndroidCompositionLocals_androidKt$ProvideAndroidCompositionLocals$3.invoke(AndroidCompositionLocals.android.kt:118)
    at androidx.compose.runtime.internal.ComposableLambdaImpl.invoke(ComposableLambda.jvm.kt:109)
    at androidx.compose.runtime.internal.ComposableLambdaImpl.invoke(ComposableLambda.jvm.kt:35)
    at androidx.compose.runtime.CompositionLocalKt.CompositionLocalProvider(CompositionLocal.kt:228)
    at androidx.compose.ui.platform.AndroidCompositionLocals_androidKt.ProvideAndroidCompositionLocals(AndroidCompositionLocals.android.kt:110)
    at androidx.compose.ui.platform.WrappedComposition$setContent$1$1$2.invoke(Wrapper.android.kt:139)
    at androidx.compose.ui.platform.WrappedComposition$setContent$1$1$2.invoke(Wrapper.android.kt:138)
    at androidx.compose.runtime.internal.ComposableLambdaImpl.invoke(ComposableLambda.jvm.kt:109)
    at androidx.compose.runtime.internal.ComposableLambdaImpl.invoke(ComposableLambda.jvm.kt:35)
    at androidx.compose.runtime.CompositionLocalKt.CompositionLocalProvider(CompositionLocal.kt:248)
    at androidx.compose.ui.platform.WrappedComposition$setContent$1$1.invoke(Wrapper.android.kt:138)
    at androidx.compose.ui.platform.WrappedComposition$setContent$1$1.invoke(Wrapper.android.kt:123)
    at androidx.compose.runtime.internal.ComposableLambdaImpl.invoke(ComposableLambda.jvm.kt:109)
    at androidx.compose.runtime.internal.ComposableLambdaImpl.invoke(ComposableLambda.jvm.kt:35)
    at androidx.compose.runtime.ActualJvm_jvmKt.invokeComposable(ActualJvm.jvm.kt:90)
    at androidx.compose.runtime.ComposerImpl.doCompose(Composer.kt:3302)
    at androidx.compose.runtime.ComposerImpl.composeContent$runtime_release(Composer.kt:3235)
    at androidx.compose.runtime.CompositionImpl.composeContent(Composition.kt:725)
    at androidx.compose.runtime.Recomposer.composeInitial$runtime_release(Recomposer.kt:1071)
    at androidx.compose.runtime.CompositionImpl.composeInitial(Composition.kt:633)
    at androidx.compose.runtime.CompositionImpl.setContent(Composition.kt:619)
    at androidx.compose.ui.platform.WrappedComposition$setContent$1.invoke(Wrapper.android.kt:123)
    at androidx.compose.ui.platform.WrappedComposition$setContent$1.invoke(Wrapper.android.kt:114)
    at androidx.compose.ui.platform.AndroidComposeView.setOnViewTreeOwnersAvailable(AndroidComposeView.android.kt:1289)
    at androidx.compose.ui.platform.WrappedComposition.setContent(Wrapper.android.kt:114)
    at androidx.compose.ui.platform.WrappedComposition.onStateChanged(Wrapper.android.kt:164)
    at androidx.lifecycle.LifecycleRegistry$ObserverWithState.dispatchEvent(LifecycleRegistry.jvm.kt:320)
    at androidx.lifecycle.LifecycleRegistry.addObserver(LifecycleRegistry.jvm.kt:198)
    at androidx.compose.ui.platform.WrappedComposition$setContent$1.invoke(Wrapper.android.kt:121)
    at androidx.compose.ui.platform.WrappedComposition$setContent$1.invoke(Wrapper.android.kt:114)
    at androidx.compose.ui.platform.AndroidComposeView.onAttachedToWindow(AndroidComposeView.android.kt:1364)
    at android.view.View.dispatchAttachedToWindow(View.java:22257)
    at android.view.ViewGroup.dispatchAttachedToWindow(ViewGroup.java:3494)
    at android.view.ViewGroup.dispatchAttachedToWindow(ViewGroup.java:3501)
    at android.view.ViewGroup.dispatchAttachedToWindow(ViewGroup.java:3501)
    at android.view.ViewGroup.dispatchAttachedToWindow(ViewGroup.java:3501)
    at android.view.ViewGroup.dispatchAttachedToWindow(ViewGroup.java:3501)
    at android.view.ViewGroup.dispatchAttachedToWindow(ViewGroup.java:3501)
    at android.view.ViewGroup.dispatchAttachedToWindow(ViewGroup.java:3501)
    at android.view.ViewRootImpl.performTraversals(ViewRootImpl.java:3207)
    at android.view.ViewRootImpl.doTraversal(ViewRootImpl.java:2659)
    at android.view.ViewRootImpl$TraversalRunnable.run(ViewRootImpl.java:9789)
    at android.view.Choreographer$CallbackRecord.run(Choreographer.java:1399)
    at android.view.Choreographer$CallbackRecord.run(Choreographer.java:1408)
    at android.view.Choreographer.doCallbacks(Choreographer.java:1008)
    at android.view.Choreographer.doFrame(Choreographer.java:938)
    at android.view.Choreographer$FrameDisplayEventReceiver.run(Choreographer.java:1382)
    at android.os.Handler.handleCallback(Handler.java:959)
    at android.os.Handler.dispatchMessage(Handler.java:100)
    at android.os.Looper.loopOnce(Looper.java:232)
    at android.os.Looper.loop(Looper.java:317)
    at android.app.ActivityThread.main(ActivityThread.java:8501)
    at java.lang.reflect.Method.invoke(Native Method)
    at com.android.internal.os.RuntimeInit$MethodAndArgsCaller.run(RuntimeInit.java:552)
    at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:878)
    

    不确定这是个问题,但我最近从英特尔MacBook换成了M1。 克隆了我的项目并继续我停止的工作,然后更新了依赖项,因为安卓工作室暗示有更新。

    我的依赖项如下:

    dependencies {
        implementation("androidx.core:core-ktx:1.13.1")
        implementation("androidx.lifecycle:lifecycle-runtime-ktx:2.8.0")
        implementation("androidx.activity:activity-compose:1.9.0")
        implementation(platform("androidx.compose:compose-bom:2024.05.00"))
        implementation("androidx.compose.foundation:foundation")
        implementation("androidx.compose.ui:ui")
        implementation("androidx.compose.ui:ui-text")
        implementation("androidx.compose.ui:ui-graphics")
        implementation("androidx.compose.ui:ui-tooling-preview")
        implementation("androidx.compose.material3:material3")
        implementation("androidx.navigation:navigation-compose:2.7.7")
        implementation("androidx.appcompat:appcompat:1.6.1")
        // DataStore
        implementation("androidx.datastore:datastore:1.1.1")
        // Glide
        implementation("com.github.bumptech.glide:compose:1.0.0-beta01")
        // Hilt
        implementation("com.google.dagger:hilt-android:2.51")
        ksp("com.google.dagger:hilt-android-compiler:2.51")
        annotationProcessor("com.google.dagger:hilt-android:2.51")
        implementation("androidx.hilt:hilt-navigation-compose:1.2.0")
        implementation("androidx.hilt:hilt-work:1.2.0")
        ksp("androidx.hilt:hilt-compiler:1.2.0")
        // Kotlin Serialization
        implementation("org.jetbrains.kotlinx:kotlinx-serialization-json:1.0.1")
        // Lifecycle
        implementation("androidx.lifecycle:lifecycle-viewmodel-ktx:2.8.0")
        implementation("androidx.lifecycle:lifecycle-extensions:2.2.0")
        implementation("androidx.lifecycle:lifecycle-runtime-compose:2.8.0")
        // LiveData
        implementation("androidx.compose.runtime:runtime-livedata")
        // Media
        implementation("androidx.media3:media3-exoplayer:1.3.1")
        implementation("androidx.media3:media3-ui:1.3.1")
        implementation("androidx.media3:media3-session:1.3.1")
        // OkHttp
        implementation(platform("com.squareup.okhttp3:okhttp-bom:4.11.0"))
        implementation("com.squareup.okhttp3:okhttp")
        implementation("com.squareup.okhttp3:logging-interceptor")
        // Protobuf
        implementation("com.google.protobuf:protobuf-javalite:3.18.0")
        // Retrofit
        implementation("com.squareup.retrofit2:retrofit:2.9.0")
        implementation("com.squareup.retrofit2:converter-gson:2.9.0")
        // Room
        implementation("androidx.room:room-runtime:2.6.1")
        annotationProcessor("androidx.room:room-compiler:2.6.1")
        ksp("androidx.room:room-compiler:2.6.1")
        implementation("androidx.room:room-ktx:2.6.1")
        // WorkManager
        implementation("androidx.work:work-runtime-ktx:2.9.0")
    
        // Test dependencies
        testImplementation("junit:junit:4.13.2")
        androidTestImplementation("androidx.test.ext:junit:1.1.5")
        androidTestImplementation("androidx.test.espresso:espresso-core:3.5.1")
        androidTestImplementation(platform("androidx.compose:compose-bom:2024.05.00"))
        androidTestImplementation("androidx.compose.ui:ui-test-junit4")
        androidTestImplementation("androidx.navigation:navigation-testing:2.7.7")
        androidTestImplementation("androidx.work:work-testing:2.9.0")
        debugImplementation("androidx.compose.ui:ui-tooling")
        debugImplementation("androidx.compose.ui:ui-test-manifest")
        testImplementation("androidx.room:room-testing:2.6.1")
    }
    

    主要活动.kt

    class MainActivity : AppCompatActivity() {
        private val mainViewModel by viewModels<MainViewModel>()
    
        override fun onCreate(savedInstanceState: Bundle?) {
            super.onCreate(savedInstanceState)
    
    
            setContent {
                val context = LocalContext.current
                val uiState by mainViewModel.uiState.collectAsStateWithLifecycle()
                var showPermissionDialog by remember { mutableStateOf(false) }
                var showRationalPermissionDialog by remember { mutableStateOf(false) }
                var hasNotificationPermission by remember {
                    if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.TIRAMISU) {
                        mutableStateOf(
                            ContextCompat.checkSelfPermission(
                                context,
                                Manifest.permission.POST_NOTIFICATIONS
                            ) == PackageManager.PERMISSION_GRANTED
                        )
                    } else {
                        mutableStateOf(true)
                    }
                }
    
                val launcher = rememberLauncherForActivityResult(
                    contract = ActivityResultContracts.RequestPermission()
                ) { granted ->
                    hasNotificationPermission = granted
                    if (!granted) {
                        if (shouldShowRequestPermissionRationale(Manifest.permission.POST_NOTIFICATIONS)) {
                            showRationalPermissionDialog = true
                        } else {
                            showPermissionDialog = true
                        }
                    }
                }
    
                SettingsPermissionDialog(
                    onDismissRequest = {
                        showPermissionDialog = !showPermissionDialog
                    },
                    visible = showPermissionDialog,
                )
    
                RationalPermissionDialog(
                    onDismissRequest = {
                        showRationalPermissionDialog = !showRationalPermissionDialog
                    },
                    onClick = {
                        if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.TIRAMISU) {
                            launcher.launch(Manifest.permission.POST_NOTIFICATIONS)
                        }
                    },
                    visible = showRationalPermissionDialog,
                )
    
                if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.TIRAMISU && !hasNotificationPermission) {
                    SideEffect { launcher.launch(Manifest.permission.POST_NOTIFICATIONS) }
                }
    
                App(
                    closeApp = { this.finish() },
                    appState = uiState,
                )
            }
        }
    }
    

    MainViewModel.kt

    @HiltViewModel
    class MainViewModel @Inject constructor(
        private val userPreferencesRepository: UserPreferencesRepository
    ) : ViewModel() {
        private val _uiState = MutableStateFlow(AppUiState())
        val uiState = _uiState.asStateFlow()
    
        init {
            viewModelScope.launch {
                userPreferencesRepository.userPreferencesFlow.collect {
                    _uiState.update { state ->
                        state.copy(
                            email = it.email,
                            level = it.level,
                            username = it.username,
                            subscription = it.subscription.toSubscription()
                        )
                    }
                }
            }
        }
    }
    
    data class AppUiState(
        val email: String = "",
        val username: String = "",
        val subscription: Subscription = Subscription.Free,
        val level: Int = 1,
    )
    
    2 回复  |  直到 10 月前
        1
  •  3
  •   CommonsWare    10 月前

    这个错误符合 this issue ,因为Compose和Lifecycle版本不匹配。您正在使用生命周期 2.8.0 哪一个 马上 与稳定的Compose版本不兼容。一次创作 1.7.0 变得稳定,您可以升级以将其与Lifecycle一起使用 2.8.0 ,并且(希望)这个问题消失了。

    我建议退回到生命周期 2.7.0 来自 2.8.0 你现在正在使用的。或者,你可以尝试 the documented workarounds .

        2
  •  0
  •   codejockie    10 月前

    通过@CommonsWare的回答,我找到了这个问题的原因,那就是我已经更新了 androidx.lifecycle:lifecycle-runtime-compose androidx.compose:compose-bom 。对于前者,我将其更新为 2.8.0 后者用于 2024.05.00 。基于问题跟踪器中提供的信息 here LocalLifecycleOwner 已从移动 androidx.compose.ui lifecycle-runtime-compose 。为了使我的代码重新工作,我应用了上提供的建议修复编号2 here 因为我不想使用compose ui包的测试版。