启用R8会使应用程序崩溃



所以我在项目中通过将android.enableR8=true添加到gradle.properties来启用R8。这是我的等级文件:

buildTypes {
release {
useProguard false
minifyEnabled true
debuggable false
multiDexEnabled true
shrinkResources true
proguardFiles getDefaultProguardFile('proguard-android-optimize.txt'), 'proguard-rules.pro'
signingConfig signingConfigs.release
}
...

但当我运行构建时,当应用程序启动时,我会崩溃:

java.lang.RuntimeException: Unable to instantiate application com.example.application.MyApplication: java.lang.NullPointerException: throw with null exception
at android.app.LoadedApk.makeApplication(LoadedApk.java:1069)
at android.app.ActivityThread.handleBindApplication(ActivityThread.java:5842)
at android.app.ActivityThread.access$1100(ActivityThread.java:199)
at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1650)
at android.os.Handler.dispatchMessage(Handler.java:106)
at android.os.Looper.loop(Looper.java:193)
at android.app.ActivityThread.main(ActivityThread.java:6669)
at java.lang.reflect.Method.invoke(Native Method)
at com.android.internal.os.RuntimeInit$MethodAndArgsCaller.run(RuntimeInit.java:493)
at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:858)
Caused by: java.lang.NullPointerException: throw with null exception
at com.example.application.MyApplication.<init>(MyApplication.kt:18)
at java.lang.Class.newInstance(Native Method)
at android.app.AppComponentFactory.instantiateApplication(AppComponentFactory.java:50)
at androidx.core.app.CoreComponentFactory.instantiateApplication(CoreComponentFactory.java:52)
at android.app.Instrumentation.newApplication(Instrumentation.java:1120)
at android.app.LoadedApk.makeApplication(LoadedApk.java:1061)
at android.app.ActivityThread.handleBindApplication(ActivityThread.java:5842) 
at android.app.ActivityThread.access$1100(ActivityThread.java:199) 
at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1650) 
at android.os.Handler.dispatchMessage(Handler.java:106) 
at android.os.Looper.loop(Looper.java:193) 
at android.app.ActivityThread.main(ActivityThread.java:6669) 
at java.lang.reflect.Method.invoke(Native Method) 
at com.android.internal.os.RuntimeInit$MethodAndArgsCaller.run(RuntimeInit.java:493) 
at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:858) 

我在我的proguard文件中添加了这些,所以R8不会删除或混淆任何

-dontobfuscate
-dontshrink
-dontoptimize

应用程序仍然崩溃。

我试图通过在gradle文件中将android.enableR8=false设置为gradle.properties和useProguard true来迁移到Proguard,该应用程序运行良好,没有崩溃。

有人遇到过同样的问题吗?

顺便说一句,我的项目在科特林。

问题是我们在一些模块中捆绑了android.jar,但它应该只在bootclasspath上,正如安卓团队在我在IssueTracker上创建的问题中所说的那样。

我建议您查看R8的输出,看看是否有任何警告可以为您指明正确的方向。如果您能够始终如一地重现问题,您可以使用R8提交问题:https://issuetracker.google.com/issues/new?component=326788&模板=1025938.

我遇到了一个用R8ProGuard缩小的应用程序的问题。我只是简单地从bulid.gradle中删除了ProGuard缩小。

最新更新