Android 运行时找不到类:java.lang.NoClassDefFoundError:...

在使用百度定位SDK时发生这种问题:java.lang.NoClassDefFoundError: com.baidu.location.LocationClient 

问题出错过程:

工程原来是在R12版本下开发的,后来为了追风,我就换掉R12,改成使用R21.1了。然后从svn上检出R12版本下开发的代码(这个代码在R12下运行是完全没有错误的)。问题就来了,一旦运行代码,就报java.lang.NoClassDefFoundError。


第一次报的是我继承的BDLocationListener的Listener找不到,private class MyBDListener implements BDLocationListener 。我认为是在打包代码的时候出现问题,于是我就不使用继承直接在LocationClient.registerLocationListener(new BDLocationListener(){}),直接做了个内部类。这样果然不在包找不到Listener的错误了。但是接着就又报错:java.lang.NoClassDefFoundError: com.baidu.location.LocationClient。稍微分析一下,就觉得这不是我自己代码问题了,是第三方jar包问题啊,首先想到的是:是不是混淆的时候将其混淆了,然后就找不到这个类了?于是在proguard.cfg中添加配置如下:-keep class com.baidu.**{*;} 这样就不混淆了吧。于是再次运行,还是报同样的错误。排除混淆错误后,就真没遇到过这样的问题了,然后百度了下,有人也遇到这个问题了,他使用的R16,将lib改成libs就没问题了,但是我的工程中,jar明明就是在libs文件下!而且代码在之前的版本都能正常运行,在高版本下就不行了,肯定不是代码问题,必须是环境问题啊。经验这样告诉我。既然觉得是环境问题就肯定是高低版本区别之处出问题了,于是想当然的想到了bin目录,打开之后果然发现有几个隐藏颇深的红色×。想都没想,果断删之。如果你是在eclipse中删除的话,他只是删除了里面的几个文件,根本没有删除干净,红×照样在眼前。为了彻底删除,关闭eclipse,然后通过资源管理器找到该bin然后删除,重新打开eclipse,一般等eclipse刷新加载编译完毕应该就没错了。但是我的还是报错,于是就clean下工程,然后红色×就不见了。既然不见了,说明就没问题了呗。于是重新运行工程,错误果断没有了,成功进入主界面。


总结类似找不到第三方jar中class的解决办法:

1、如果你是R16版本,并且你的jar还是lib文件下,那么你先将lib rename为libs,然后clear工程试试还有没有问题
2、如果还不成功,你可以试探着将第三方的混淆给去掉,有些时候,就是因为混淆了第三方的代码,导致找不到第三方的类。在proguard.cfg文件中添加配置 例如:-keep class com.baidu.**{*;}
3、如果你是从低版本转移到高版本,出现某些不可思议的问题,比如在低版本正常运行的代码,在高版本中出错了,你稍微从高低版本的不同处找一下原因。比如我:删除bin然后让他自动生成下。然后的然后就没问题了。
4、如果你跟我上次遇到的问题一样,类找到了,但是发现类中的某个方法找不到,那么,你就考虑下是不是冲突问题,改一下你类的包名。(这中问题一般出现在开源代码生成的jar中,不常见)。

<think>好的,我现在遇到了一个Java中的NoClassDefFoundError问题,具体是okhttp3.internal.io的不到。用户提供的引用信息里提到了不同的情况,比如在API_21以下会报错,还有需要配置MultiDex的情况。我需要综合这些信息来到解决方法。 首先,NoClassDefFoundError通常意味着在编译存在,但运行不到。可能的原因包括依赖未正确添加、ProGuard混淆了,或者Multidex的问题导致未被加载。用户提到在低版本API出现这个问题,可能和Multidex有关,因为低版本Android有方法数限制,需要启用Multidex来解决。 引用3中提到需要在build.gradle中添加multidex依赖,并在Application中初始化MultiDex.install(this),而且必须在super.onCreate()之前调用。这可能是一个关键步骤,特别是当应用的方法数超过65536。另外,用户的问题涉及的是okhttp3.internal包下的,可能和ProGuard的混淆配置有关,需要检查是否保留了okhttp的相关。 另外,引用2中提到在低API版本出现OkHttpClient的NoClassDefFoundError,可能和依赖配置方式有关,比如是否使用了正确的依赖声明,或者是否有冲突的版本。例如,使用implementation还是compile,或者是否遗漏了某些模块。 可能的解决步骤包括: 1. 确保在build.gradle中正确添加了OkHttp的依赖,并且版本兼容。 2. 检查是否启用了Multidex,并在Application中正确配置。 3. 检查ProGuard规则,确保没有混淆或移除OkHttp的。 4. 清理并重新构建项目,避免缓存问题导致依赖未正确加载。 可能需要用户提供build.gradle的依赖部分,查看是否有错误。另外,确认项目结构是否正确,是否有多个模块导致依赖未正确传递。比如,如果某个模块依赖了OkHttp,而主模块没有正确引用,也可能导致这个问题。 还有,用户提到的错误信息中的具体,如okhttp3.internal.io.w30,可能是OkHttp内部,可能因为ProGuard去除了这些,或者依赖版本过旧,导致某些内部不存在。因此,更新OkHttp到最新稳定版可能解决问题。 总结可能的解决方案步骤: - 添加Multidex支持。 - 检查并正确配置OkHttp依赖。 - 更新ProGuard配置。 - 清理和重建项目。</think>### Java中解决`java.lang.NoClassDefFoundError: okhttp3.internal.io`问题的步骤 #### 1. 检查依赖配置 确保在`build.gradle`文件中正确声明了OkHttp依赖。例如: ```groovy dependencies { // 使用最新稳定版本(例如4.9.3) implementation 'com.squareup.okhttp3:okhttp:4.9.3' } ``` - **注意**:避免使用已过的`compile`关键字,改用`implementation`或`api`[^2]。 - **版本冲突**:检查项目中是否有其他库依赖不同版本的OkHttp,可能导致加载失败。 #### 2. 启用Multidex支持(针对低版本Android系统) 对于Android API 21以下设备,若方法数超过65536,需启用Multidex: 1. 在`build.gradle`中添加依赖: ```groovy dependencies { implementation 'com.android.support:multidex:1.0.3' } ``` 2. 在`Application`中初始化: ```java public class MyApp extends Application { @Override public void onCreate() { MultiDex.install(this); // 必须在super.onCreate()之前调用 super.onCreate(); } } ``` 确保AndroidManifest.xml中指定了该Application[^3]。 #### 3. 配置ProGuard规则 若启用了代码混淆,需在`proguard-rules.pro`中添加: ```proguard # 保留OkHttp相关 -keep class okhttp3.** { *; } -keep interface okhttp3.** { *; } ``` #### 4. 清理项目并同步 - 执行`Build > Clean Project`和`Build > Rebuild Project`。 - 在Android Studio中点击`File > Sync Project with Gradle Files`。 #### 5. 验证依赖传递性 若通过其他库间接依赖OkHttp,需确认依赖是否完整: ```groovy // 查看依赖树 ./gradlew app:dependencies ``` 若发现版本冲突,可通过强制指定版本解决: ```groovy configurations.all { resolutionStrategy.force 'com.squareup.okhttp3:okhttp:4.9.3' } ``` #### 6. 检查IDE缓存问题 - 关闭Android Studio,删除项目目录下的`.gradle`和`build`文件夹。 - 重新打开项目并同步。 --- ### 相关问题 1. **如何排查Android中的`NoClassDefFoundError`错误?** - 检查依赖配置、ProGuard规则及Multidex配置,使用`./gradlew dependencies`分析依赖树。 2. **OkHttp在低版本Android系统上为何需要特殊处理?** - Android 5.0以下使用Dalvik虚拟机,默认不支持多个Dex文件,需通过Multidex扩展。 3. **如何解决ProGuard移除必要的问题?** - 在`proguard-rules.pro`中添加保留规则,或使用`-dontwarn`忽略特定警告。 --- ### 引用来源 [^1]: `java.lang.NoClassDefFoundError`可能由依赖缺失或加载失败导致。 [^2]: 低版本Android系统需通过Multidex解决Dex文件限制问题。 : Multidex配置需在Application初始化前调用`MultiDex.install(this)`。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值