原有工程项目添加自定义的application之后出现了Didn't find class "com.xx.MainActivity" on path: DexPathList[[zip的原因

作者在新项目做自动升级需求,添加自定义application后编译报错,找不到原launchActivity的class。经排查,问题根源是配置项build.gradle中的multiDexEnabled true属性。因代码方法数超65k,低版本dalvik加载主dex时会报错,还给出了低版本的额外配置及解决参考链接。

新近入职,拿到新的项目代码之后做了一个自动升级的需求,需要在原有项目上添加一个自定义的application,结果非常简单的一个步骤报出在编译的apk中找不到原有的launchActivity的class了,原本的项目当然是正常运行的,注册表也是对的,网上一搜不管是csdn还是stackOverflow基本都是在说注册表注册表,绝对路径相对路径的问题,也有说application的单例需要注意的点,虽然看到很多常见问题不过都不是我这边的根因。

后来终于查到了是配置项build.grudle中的multiDexEnabled true属性问题

通常看一个app最先看的两个入口应该就是注册表AndroidManifest.xml和配置项build.gradle,这种添加空壳application导致文件系统出错的也应该在这里面去寻找原因。

 

 

multiDexEnabled 因为我们代码的总的方法数超过了goole规定的65k个方法,导致了jvm不能编译通过我们的代码,这是后就需要使用multiDexEnabled true来进行分包编译打包,就是我们把项目打成多个编译包(dex文件),而不是一个dex文件,这在安卓5.0以上没有问题,因为5.0系统上使用art 支持多dex,但是低版本dalvik默认先加载主dex,如果启动时需要的类不在主dex内就会报错ClassNotFoundException,所以会报这个错。

在低版本配置了这个属性之后还要添加一个配置

dependencies {
    //新版本使用implementation关键字,旧版本请使用compile 'com.android.support:multidex:1.0.1'
    implementation 'com.android.support:multidex:1.0.1'
}
并且重写application时需要继承自android.support.multidex.MultiDexApplication,当然这个MultiDexApplication的父类就是Application,里面有一个install方法需要在自定义的attachBaseContext去写一下。

 

 

问题解决操作参考:https://blog.youkuaiyun.com/ymmccc/article/details/82378990

问题原理参考:https://www.jianshu.com/p/cddfc89ce947

安卓java 2025-12-18 17:12:23.103 10095-10095/com.example.demo251216 E/AndroidRuntime: FATAL EXCEPTION: main Process: com.example.demo251216, PID: 10095 java.lang.NoClassDefFoundError: Failed resolution of: Lkotlin/jvm/internal/Intrinsics; at com.skydroid.rcsdk.RCSDKManager.initSDK(Unknown Source:2) at com.example.demo251216.MainActivity.openData(MainActivity.java:293) at com.example.demo251216.MainActivity.onCreate(MainActivity.java:154) at android.app.Activity.performCreate(Activity.java:7023) at android.app.Activity.performCreate(Activity.java:7014) at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1215) at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2734) at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2859) at android.app.ActivityThread.-wrap11(Unknown Source:0) at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1592) at android.os.Handler.dispatchMessage(Handler.java:106) at android.os.Looper.loop(Looper.java:164) at android.app.ActivityThread.main(ActivityThread.java:6518) at java.lang.reflect.Method.invoke(Native Method) at com.android.internal.os.RuntimeInit$MethodAndArgsCaller.run(RuntimeInit.java:438) at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:807) Caused by: java.lang.ClassNotFoundException: Didn’t find class “kotlin.jvm.internal.Intrinsics” on path: DexPathList[[zip file “/data/app/com.example.demo251216-9FQl5OevwxmaNwhMwMtxdw==/base.apk”],nativeLibraryDirectories=[/data/app/com.example.demo251216-9FQl5OevwxmaNwhMwMtxdw==/lib/arm64, /data/app/com.example.demo251216-9FQl5OevwxmaNwhMwMtxdw==/base.apk!/lib/arm64-v8a, /system/lib64, /vendor/lib64]] at dalvik.system.BaseDexClassLoader.findClass(BaseDexClassLoader.java:125) at java.lang.ClassLoader.loadClass(ClassLoader.java:379) at java.lang.ClassLoader.loadClass(ClassLoader.java:312) at com.skydroid.rcsdk.RCSDKManager.initSDK(Unknown Source:2) at com.example.demo251216.MainActivity.openData(MainActivity.java:293) at com.example.demo251216.MainActivity.onCreate(MainActivity.java:154) at android.app.Activity.performCreate(Activity.java:7023) at android.app.Activity.performCreate(Activity.java:7014) at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1215) at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2734) at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2859) at android.app.ActivityThread.-wrap11(Unknown Source:0) at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1592) at android.os.Handler.dispatchMessage(Handler.java:106) at android.os.Looper.loop(Looper.java:164) at android.app.ActivityThread.main(ActivityThread.java:6518) at java.lang.reflect.Method.invoke(Native Method) at com.android.internal.os.RuntimeInit$MethodAndArgsCaller.run(RuntimeInit.java:438) at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:807)
最新发布
12-19
10/30 10:31:58: Launching 'app' on OnePlus GM1900. App restart successful without requiring a re-install. $ adb shell am start -n "com.example.myapplication/com.example.myapplication.MainActivity" -a android.intent.action.MAIN -c android.intent.category.LAUNCHER Connected to process 3090 on device 'oneplus-gm1900-127.0.0.1:5555'. Capturing and displaying logcat messages from application. This behavior can be disabled in the "Logcat output" section of the "Debugger" settings page. I/art: Late-enabling -Xcheck:jni D/libnativebridge: call UnloadNativeBridge! state=1 W/System: ClassLoader referenced unknown path: /data/app/com.example.myapplication-1/lib/x86_64 W/art: Before Android 4.1, method android.graphics.PorterDuffColorFilter androidx.vectordrawable.graphics.drawable.VectorDrawableCompat.updateTintFilter(android.graphics.PorterDuffColorFilter, android.content.res.ColorStateList, android.graphics.PorterDuff$Mode) would have incorrectly overridden the package-private method in android.graphics.drawable.Drawable I/art: Rejecting re-init on previously-failed class java.lang.Class<androidx.core.view.ViewCompat$2>: java.lang.NoClassDefFoundError: Failed resolution of: Landroid/view/View$OnUnhandledKeyEventListener; at void androidx.core.view.ViewCompat.setOnApplyWindowInsetsListener(android.view.View, androidx.core.view.OnApplyWindowInsetsListener) (ViewCompat.java:2463) at android.view.ViewGroup androidx.appcompat.app.AppCompatDelegateImpl.createSubDecor() (AppCompatDelegateImpl.java:938) at void androidx.appcompat.app.AppCompatDelegateImpl.ensureSubDecor() (AppCompatDelegateImpl.java:806) at void androidx.appcompat.app.AppCompatDelegateImpl.setContentView(int) (AppCompatDelegateImpl.java:693) at void androidx.appcompat.app.AppCompatActivity.setContentView(int) (AppCompatActivity.java:170) at void com.example.myapplication.MainActivity.onCreate(android.os.Bundle) (MainActivity.java:19) at void android.app.Activity.performCreate(android.os.Bundle) (Activity.java:6701) at void android.app.Instrumentation.callActivityOnCreate(android.app.Activity, android.os.Bundle) (Instrumentation.java:1118) at android.app.Activity android.app.ActivityThread.performLaunchActivity(android.app.ActivityThread$ActivityClientRecord, android.content.Intent) (ActivityThread.java:2657) at void android.app.ActivityThread.handleLaunchActivity(android.app.ActivityThread$ActivityClientRecord, android.content.Intent, java.lang.String) (ActivityThread.java:2765) at void android.app.ActivityThread.-wrap14(android.app.ActivityThread, android.app.ActivityThread$ActivityClientRecord, android.content.Intent, java.lang.String) (ActivityThread.java:-1) at void android.app.ActivityThread$H.handleMessage(android.os.Message) (ActivityThread.java:1488) at void android.os.Handler.dispatchMessage(android.os.Message) (Handler.java:102) at void android.os.Looper.loop() (Looper.java:154) at void android.app.ActivityThread.main(java.lang.String[]) (ActivityThread.java:6305) at java.lang.Object java.lang.reflect.Method.invoke!(java.lang.Object, java.lang.Object[]) (Method.java:-2) at void com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run() (ZygoteInit.java:892) at void com.android.internal.os.ZygoteInit.main(java.lang.String[]) (ZygoteInit.java:782) Caused by: java.lang.ClassNotFoundException: Didn't find class "android.view.View$OnUnhandledKeyEventListener" on path: DexPathList[[zip file "/data/app/com.example.myapplication-1/base.apk"],nativeLibraryDirectories=[/data/app/com.example.myapplication-1/lib/x86_64, /system/lib64, /vendor/lib64]] at java.lang.Class dalvik.system.BaseDexClassLoader.findClass(java.lang.String) (BaseDexClassLoader.java:56) at java.lang.Class java.lang.ClassLoader.loadClass(java.lang.String, boolean) (ClassLoader.java:380) at java.lang.Class java.lang.ClassLoader.loadClass(java.lang.String) (ClassLoader.java:312) at void androidx.core.view.ViewCompat.setOnApplyWindowInsetsListener(android.view.View, androidx.core.view.OnApplyWindowInsetsListener) (ViewCompat.java:2463) at android.view.ViewGroup androidx.appcompat.app.AppCompatDelegateImpl.createSubDecor() (AppCompatDelegateImpl.java:938) at void androidx.appcompat.app.AppCompatDelegateImpl.ensureSubDecor() (AppCompatDelegateImpl.java:806) at void androidx.appcompat.app.AppCompatDelegateImpl.setContentView(int) (AppCompatDelegateImpl.java:693) at void androidx.appcompat.app.AppCompatActivity.setContentView(int) (AppCompatActivity.java:170) at void com.example.myapplication.MainActivity.onCreate(android.os.Bundle) (MainActivity.java:19) at void android.app.Activity.performCreate(android.os.Bundle) (Activity.java:6701) at void android.app.Instrumentation.callActivityOnCreate(android.app.Activity, android.os.Bundle) (Instrumentation.java:1118) at android.app.Activity android.app.ActivityThread.performLaunchActivity(android.app.ActivityThread$ActivityClientRecord, android.content.Intent) (ActivityThread.java:2657) at void android.app.ActivityThread.handleLaunchActivity(android.app.ActivityThread$ActivityClientRecord, android.content.Intent, java.lang.String) (ActivityThread.java:2765) at void android.app.ActivityThread.-wrap14(android.app.ActivityThread, android.app.ActivityThread$ActivityClientRecord, android.content.Intent, java.lang.String) (ActivityThread.java:-1) at void android.app.ActivityThread$H.handleMessage(android.os.Message) (ActivityThread.java:1488) at void android.os.Handler.dispatchMessage(android.os.Message) (Handler.java:102) at void android.os.Looper.loop() (Looper.java:154) at void android.app.ActivityThread.main(java.lang.String[]) (ActivityThread.java:6305) at java.lang.Object java.lang.reflect.Method.invoke!(java.lang.Object, java.lang.Object[]) (Method.java:-2) at void com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run() (ZygoteInit.java:892) at void com.android.internal.os.ZygoteInit.main(java.lang.String[]) (ZygoteInit.java:782) D/AndroidRuntime: Shutting down VM E/AndroidRuntime: FATAL EXCEPTION: main Process: com.example.myapplication, PID: 3090 java.lang.RuntimeException: Unable to resume activity {com.example.myapplication/com.example.myapplication.MainActivity}: java.lang.IllegalArgumentException: column '_id' does not exist at android.app.ActivityThread.performResumeActivity(ActivityThread.java:3468) at android.app.ActivityThread.handleResumeActivity(ActivityThread.java:3508) at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2771) at android.app.ActivityThread.-wrap14(ActivityThread.java) at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1488) at android.os.Handler.dispatchMessage(Handler.java:102) at android.os.Looper.loop(Looper.java:154) at android.app.ActivityThread.main(ActivityThread.java:6305) at java.lang.reflect.Method.invoke(Native Method) at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:892) at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:782) Caused by: java.lang.IllegalArgumentException: column '_id' does not exist at android.database.AbstractCursor.getColumnIndexOrThrow(AbstractCursor.java:333) at android.widget.CursorAdapter.swapCursor(CursorAdapter.java:378) at android.widget.SimpleCursorAdapter.swapCursor(SimpleCursorAdapter.java:346) at android.widget.CursorAdapter.changeCursor(CursorAdapter.java:349) at com.example.myapplication.MainActivity.refreshListView(MainActivity.java:61) at com.example.myapplication.MainActivity.onResume(MainActivity.java:56) at android.app.Instrumentation.callActivityOnResume(Instrumentation.java:1269) at android.app.Activity.performResume_orig(Activity.java:6822) at android.app.Activity.performResume(Activity.java:6803) at android.app.ActivityThread.performResumeActivity(ActivityThread.java:3445) at android.app.ActivityThread.handleResumeActivity(ActivityThread.java:3508)  at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2771)  at android.app.ActivityThread.-wrap14(ActivityThread.java)  at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1488)  at android.os.Handler.dispatchMessage(Handler.java:102)  at android.os.Looper.loop(Looper.java:154)  at android.app.ActivityThread.main(ActivityThread.java:6305)  at java.lang.reflect.Method.invoke(Native Method)  at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:892)  at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:782)  为什么会出错
10-31
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值