关于分包后的apk运行发生java.lang.NoClassDefFoundError的问题

本文分享了一次解决Android应用因方法数量过多导致的DEX文件限制问题的经验。通过使用multidex库并进行适当配置,使得应用能够在Android 5.0及以下版本上正常运行。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

这次在开发过程中遇到了应用提交应用市场审核不通过的问题,小米开放平台给我发来了Log文件,一看发现是 java.lang.NoClassDefFoundError 这个错误引起了,反复查看代码就是没找到问题出在哪儿,百度半天一点进展没有。

然后谷歌了一下  出来了很多stackoverflow的结果  于是  我解决了  

发下原地址:http://stackoverflow.com/questions/32110859/fatal-exception-java-lang-noclassdeffounderror-android-support-v7-appcompat-r

具体就是因为我项目中引用各种第三方sdk、jar包导致项目开始变得臃肿,然后方法名过多做了分包的处理

重点就是这个  做了分包处理后 我周围的安卓机都是Android 5.0以上的系统  Android 5.0以上的系统能够正常读取拆分后的dex包 而Android 5.0以下的版本则不能

为此 我用multirom给我的Nexus 5多刷了一个Android 4.4版本miui系统  发现确实是这样 应用一启动直接就崩了

然后根据stackoverflow上的大神给出了方法成功解决了这个问题。

就酱。


我把解决问题关键内容直接贴出来好了


I faced the same issue and fixed it. It is issue with Dex limit. Because the dex limit is reached, it creates two dex files. Lollipop knows how to read, pre-Lollipop has no idea unless you specify it in the Application class.

Please make sure following is in place:

in build.gradle

dependencies {
    compile 'com.android.support:multidex:1.0.0'
}
defaultConfig {          
    multiDexEnabled true
}

IMPORTANT to support pre-Lollipop:

In Manifest, under the application tag,

<application
        ...
        android:name="android.support.multidex.MultiDexApplication">
        ...
</application>

Or if you have used your own Application class, make your Application override attachBaseContext starting with

 import android.support.multidex.MultiDexApplication;
 import android.support.multidex.MultiDex;

 public class MyApplication extends MultiDexApplication {
 // ......

    @Override
    protected void attachBaseContext(Context base) {
        super.attachBaseContext(base);
        MultiDex.install(this);
    }
}

--------- beginning of main --------- beginning of system 2025-06-12 22:46:09.322 24133-24133 tware.hiltlearn com.software.hiltlearn E BBinder_init Processname <pre-initialized> 2025-06-12 22:46:09.322 24133-24133 tware.hiltlearn com.software.hiltlearn E BBinder_init hasGetProcessName <pre-initialized> 2025-06-12 22:46:09.604 24133-24133 UltraFrame...entFactory com.software.hiltlearn E Failed to create UltraFrameworkComponentFactoryImpl java.lang.ClassNotFoundException: android.os.ufw.UltraFrameworkComponentFactoryImpl at java.lang.Class.classForName(Native Method) at java.lang.Class.forName(Class.java:607) at java.lang.Class.forName(Class.java:512) at android.os.ufw.UltraFrameworkComponentFactory.getInstance(UltraFrameworkComponentFactory.java:78) at android.view.SurfaceControl.<init>(SurfaceControl.java:1358) at android.view.ViewRootImpl.<init>(ViewRootImpl.java:953) at android.view.ViewRootImpl.<init>(ViewRootImpl.java:1404) at android.view.WindowManagerGlobal.addView(WindowManagerGlobal.java:469) at android.view.WindowManagerImpl.addView(WindowManagerImpl.java:169) at android.app.ActivityThread.handleResumeActivity(ActivityThread.java:6088) at android.app.servertransaction.ResumeActivityItem.execute(ResumeActivityItem.java:70) at android.app.servertransaction.ActivityTransactionItem.execute(ActivityTransactionItem.java:60) at android.app.servertransaction.TransactionExecutor.executeLifecycleItem(TransactionExecutor.java:271) at android.app.servertransaction.TransactionExecutor.executeTransactionItems(TransactionExecutor.java:146) at android.app.servertransaction.TransactionExecutor.execute(TransactionExecutor.java:120) at android.app.ActivityThread$H.handleMessage(ActivityThread.java:3088) at android.os.Handler.dispatchMessage(Handler.java:109) at android.os.Looper.loopOnce(Looper.java:250) at android.os.Looper.loop(Looper.java:340) at android.app.ActivityThread.main(ActivityThread.java:9875) at java.lang.reflect.Method.invoke(Native Method) at com.android.internal.os.RuntimeInit$MethodAndArgsCaller.run(RuntimeInit.java:621) at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:957) Caused by: java.lang.ClassNotFoundException: android.os.ufw.UltraFrameworkComponentFactoryImpl at java.lang.Class.classForName(Native Method) at java.lang.BootClassLoader.findClass(ClassLoader.java:2693) at java.lang.BootClassLoader.loadClass(ClassLoader.java:2753) at java.lang.ClassLoader.loadClass(ClassLoader.java:573) at java.lang.Class.classForName(Native Method)  at java.lang.Class.forName(Class.java:607)  at java.lang.Class.forName(Class.java:512)  at android.os.ufw.UltraFrameworkComponentFactory.getInstance(UltraFrameworkComponentFactory.java:78)  at android.view.SurfaceControl.<init>(SurfaceControl.java:1358)  at android.view.ViewRootImpl.<init>(ViewRootImpl.java:953)  at android.view.ViewRootImpl.<init>(ViewRootImpl.java:1404)  at android.view.WindowManagerGlobal.addView(WindowManagerGlobal.java:469)  at android.view.WindowManagerImpl.addView(WindowManagerImpl.java:169)  at android.app.ActivityThread.handleResumeActivity(ActivityThread.java:6088)  at android.app.servertransaction.ResumeActivityItem.execute(ResumeActivityItem.java:70)  at android.app.servertransaction.ActivityTransactionItem.execute(ActivityTransactionItem.java:60)  at android.app.servertransaction.TransactionExecutor.executeLifecycleItem(TransactionExecutor.java:271)  at android.app.servertransaction.TransactionExecutor.executeTransactionItems(TransactionExecutor.java:146)  at android.app.servertransaction.TransactionExecutor.execute(TransactionExecutor.java:120)  at android.app.ActivityThread$H.handleMessage(ActivityThread.java:3088)  at android.os.Handler.dispatchMessage(Handler.java:109)  at android.os.Looper.loopOnce(Looper.java:250)  at android.os.Looper.loop(Looper.java:340)  at android.app.ActivityThread.main(ActivityThread.java:9875)  at java.lang.reflect.Method.invoke(Native Method)  at com.android.internal.os.RuntimeInit$MethodAndArgsCaller.run(RuntimeInit.java:621)  at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:957)  Caused by: java.lang.NoClassDefFoundError: Class not found using the boot class loader; no stack trace available 2025-06-12 22:46:09.682 24133-24133 TAG com.software.hiltlearn E 初始化
06-13
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值