问题描述
我们的一个 Unity 应用程序最近在 Android 上遇到了一个问题,即 Application 类不在主 dex 中。结果是应用程序构建,但在启动时崩溃。
这是一个现有的 Android 应用程序,启用了 multidex,并且该应用程序扩展了 MultiDexApplication。我按照 Declare classes required in the primary DEX file 的说明进行操作,但抛出了相同的异常。
java.lang.RuntimeException: Unable to instantiate application com.example.Application: java.lang.classNotFoundException: Didn't find class "com.example.Application" on path: DexPathList
同样,在主 dex 中也找不到 MultiDexApplication 类,如堆栈跟踪所示:
Caused by: java.lang.classNotFoundException: Didn't find class "androidx.multidex.MultiDexApplication" on path: DexPathList
我试过了
- 添加 multiDexKeepFile.txt (
multiDexKeepFile file('multiDexKeepFile.txt')
) - 添加 multiDexKeepProguard.pro (
multiDexKeepProguard file('multiDexKeepProguard.pro')
)
- 注意:无论 proguard 是启用还是禁用,都会出现此问题。
当我将 multiDexKeep 文件添加到 gradle 文件所在的 Assets/Plugins/Android/ 时,即使我导出项目,Unity 似乎也忽略了它们。所以我也试过了:
- 使用 IPostprocessBuildWithReport 手动添加 multiDexKeep 文件。
- 使用 IPreprocessBuildWithReport 手动添加 multiDexKeep 文件。
- 制作一个包含 multiDexKeep 文件的 Android 库。
Unity 似乎无法自行获取 multiDexKeep 文件,但可以通过任一进程导出它们。然而,即使我导出项目并在Android Studio中构建项目,这些类仍然没有出现在主dex中。
有人解决过这个问题吗?
multiDexKeepFile.txt:
androidx/multidex/MultiDexApplication.class
com/example/Application.class
multiDexKeepProguard.pro:
-keep class androidx.multidex.MultiDexApplication
-keep class com.example.Application
解决方法
我能够解决这个问题。如果文件位于 .androidlib 内,Unity 似乎可以识别这些文件。
我还发现了对我们不再在主活动中使用的 sdk 的引用。去掉代码和sdk似乎也安抚了dex大神。