Kotlin:将 DispatchTask 转换为字符串时出现 ArrayIndexOutOfBoundsException

Kotlin: ArrayIndexOutOfBoundsException during converting DispatchTask to string

我们已经将我们的第一个 Kotlin 作品发布到生产环境中,我们遇到了这个堆栈跟踪崩溃:

Fatal Exception: java.lang.ArrayIndexOutOfBoundsException: length=0; index=0
       at kotlin.jvm.internal.ReflectionFactory.renderLambdaToString(ReflectionFactory.java:47)
       at kotlin.jvm.internal.Reflection.renderLambdaToString(Reflection.java:80)
       at kotlin.jvm.internal.Lambda.toString(Lambda.kt:22)
       at java.lang.StringBuilder.append(StringBuilder.java:202)
       at kotlinx.coroutines.experimental.DispatchedContinuation.toString(CoroutineDispatcher.kt:192)
       at java.lang.StringBuilder.append(StringBuilder.java:202)
       at kotlinx.coroutines.experimental.DispatchTask.toString(CoroutineDispatcher.kt:124)
       at java.lang.StringBuilder.append(StringBuilder.java:202)
       at android.os.Looper.loop(Looper.java:160)
       at android.app.ActivityThread.main(ActivityThread.java:5637)
       at java.lang.reflect.Method.invoke(Method.java)
       at java.lang.reflect.Method.invoke(Method.java:372)
       at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:960)
       at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:755)

Google 向我们展示了 Android 5 上 100% 发生的情况。Crashlytics/Fabric 还展示了 Android 4.4 中的两次崩溃。较新的 Android 版本没有崩溃。

我不知道如何防止此崩溃或如何复制它。

当前版本:

这是 Kotlin 反射中的一个错误。同时,我建议升级到最新版本的kotlinx.coroutines库(你可以找到最新版本here)。由于版本 0.17 DispatchTask.toString 不再尝试将 lambda 转换为字符串。它的 toString 实施现在实际上更有用,并且具有更多用于调试目的的相关信息。