Fixed
Status Update
Comments
ap...@google.com <ap...@google.com> #2
A couple of questions:
1. Have you saw crash in real device or only in simulators?
2. Do you use dynamic feature for language ID?
1. Have you saw crash in real device or only in simulators?
2. Do you use dynamic feature for language ID?
il...@google.com <il...@google.com> #3
Tested on Android 12 Emulator with custom executor, but cannot repro this issue.
na...@google.com <na...@google.com> #4
-
Second crash in the description is from a real device. Experienced it myself on two different Xiaomi phones, plus lots of crashes from users in the Google Play console.
-
Dynamic features are not used in the application.
As a wild guess, I have downgraded build tools from 31.0.0 to 30.0.3, compileSdk from 31 to 30, and moved all work with Language ID to the service in a separate process (just to be sure that crash can kill secondary process instead of main). This combination is in beta for 2 days by now and I don't see any SIGSEGV crashes.
Description
Currently, when using
SavedStateHandle
APIs such asget(key): T
,getLiveData(key): MutableLiveData
, andgetStateFlow(key): StateFlow
simultaneously with a matchingkey
, theSavedStateHandle
synchronizes the value between them.However, synchronizing between a
MutableStateFlow
and aMutableLiveData
would be very challenging, and now thatSavedStateHandle
is Multiplatform,MutableLiveData
is not available in Kotlin Multiplatform.For this reason, we have decided to:
getMutableStateFlow(key): MutableStateFlow
.getMutableStateFlow(key): MutableStateFlow
and agetLiveData(key): MutableLiveData
mutually exclusive.Therefore, once a
key
is used by one of the two methods, attempting to get the other with the same key will result in an exception.Please note that
getStateFlow(key): StateFlow
will remain unchanged and is not mutually exclusive withgetLiveData(key): MutableLiveData
to maintain backward compatibility.These changes will also address the following feature requests: b/354497131 and b/235574686