Android studio value 2 (DexIndexOverflowException,OutOfMemoryError,NoClassDefFoundError错误)

com.android.dex.DexIndexOverflowException: method ID not in [0, 0xffff]: 65536

这个问题 如果直接看异常最下方 也是value值为2    一开让我和前面所说的那个 资源重复加载问题混淆了

找了很多地方发现并没有重复


这个其实是说

同时在工程中引入了多个第三方jar包,导致调用的方法数超过了android设定的65536个(DEX 64K problem),进而导致dex无法生成,也就无法生成APK文件。


1、谷歌官方已经给出了相关的文档,参照网上搜索的资料,首先,我的问题是:

复制代码
Error:Execution failed for task ':duchazhushou:dexRelease'.
> com.android.ide.common.internal.LoggedErrorException: Failed to run command:
    C:\Users\jeff\AppData\Local\Android\sdk\android-sdk\build-tools\21.1.1\dx.bat --dex --output D:\dev\android\Duchazhushou_TDT\duchazhushou\build\intermediates\dex\release --input-list=D:\dev\android\Duchazhushou_TDT\duchazhushou\build\intermediates\tmp\dex\release\inputList.txt
Error Code:
    2
Output:
    UNEXPECTED TOP-LEVEL EXCEPTION:
    com.android.dex.DexIndexOverflowException: method ID not in [0, 0xffff]: 65536
        at com.android.dx.merge.DexMerger$6.updateIndex(DexMerger.java:502)
        at com.android.dx.merge.DexMerger$IdMerger.mergeSorted(DexMerger.java:277)
        at com.android.dx.merge.DexMerger.mergeMethodIds(DexMerger.java:491)
        at com.android.dx.merge.DexMerger.mergeDexes(DexMerger.java:168)
        at com.android.dx.merge.DexMerger.merge(DexMerger.java:189)
        at com.android.dx.command.dexer.Main.mergeLibraryDexBuffers(Main.java:454)
        at com.android.dx.command.dexer.Main.runMonoDex(Main.java:302)
        at com.android.dx.command.dexer.Main.run(Main.java:245)
        at com.android.dx.command.dexer.Main.main(Main.java:214)
        at com.android.dx.command.Main.main(Main.java:106)
复制代码

2、在项目的build.gradle文件的dependencies 节中添加分包设置:

dependencies { 
... 
   compile 'com.android.support:multidex:' 
   ... 
}

3、通过在defaultConfig节中设置multiDexEnabled标签为true,开启multi-dexing支持.

defaultConfig { 
   ... 
multiDexEnabled true 
... 
}

---------------------------------------------------------------------------------------------------------------------------------------------------------

走到这里运行会出现内存溢出错误lang.OutOfMemoryError: GC overhead limit exceeded

UNEXPECTED TOP-LEVEL ERROR:
java.lang.OutOfMemoryError: GC overhead limit exceeded
    at com.android.dx.cf.code.ConcreteMethod.makeSourcePosistion(ConcreteMethod.java:254)
    at com.android.dx.cf.code.RopperMachine.run(RopperMachine.java:306)
    at com.android.dx.cf.code.Simulator$SimVisitor.visitLocal(Simulator.java:612)
    at com.android.dx.cf.code.BytecodeArray.parseInstruction(BytecodeArray.java:367)
    at com.android.dx.cf.code.Simulator.simulate(Simulator.java:94)
    at com.android.dx.cf.code.Ropper.processBlock(Ropper.java:787)
    at com.android.dx.cf.code.Ropper.doit(Ropper.java:742)
    at com.android.dx.cf.code.Ropper.convert(Ropper.java:349)
    at com.android.dx.dex.cf.CfTranslator.processMethods(CfTranslator.java:280)
    at com.android.dx.dex.cf.CfTranslator.translate0(CfTranslator.java:137)
    at com.android.dx.dex.cf.CfTranslator.translate(CfTranslator.java:93)
    at com.android.dx.command.dexer.Main.processClass(Main.java:729)
    at com.android.dx.command.dexer.Main.processFileBytes(Main.java:673)
    at com.android.dx.command.dexer.Main.access$300(Main.java:82)
    at com.android.dx.command.dexer.Main$1.processFileBytes(Main.java:602)
    at com.android.dx.cf.direct.ClassPathOpener.processArchive(ClassPathOpener.java:284)
    at com.android.dx.cf.direct.ClassPathOpener.processOne(ClassPathOpener.java:166)
    at com.android.dx.cf.direct.ClassPathOpener.process(ClassPathOpener.java:144)
    at com.android.dx.command.dexer.Main.processOne(Main.java:632)
    at com.android.dx.command.dexer.Main.processAllFiles(Main.java:505)
    at com.android.dx.command.dexer.Main.runMultiDex(Main.java:332)
    at com.android.dx.command.dexer.Main.run(Main.java:243)
    at com.android.dx.command.dexer.Main.main(Main.java:214)
    at com.android.dx.command.Main.main(Main.java:106)
内存溢出 就需要分配内存

android {
    compileSdkVersion 21
    buildToolsVersion "21.1.1"

    defaultConfig {
        ...
        multiDexEnabled true
    }

...
    dexOptions {
        incremental true
        javaMaxHeapSize "4g"
    }
}
这下该搞定了吧

---------------------------------------------------------------------------------------------------------------------------------------------------------

然后又爆出了一个Java.lang.NoClassDefFoundError错误

NoClassDefFoundError错误发生的原因

NoClassDefFoundError错误的发生,是因为Java虚拟机在编译时能找到合适的类,而在运行时不能找到合适的类导致的错误。例如在运行时我们想调用某个类的方法或者访问这个类的静态成员的时候,发现这个类不可用,此时Java虚拟机就会抛出NoClassDefFoundError错误。与ClassNotFoundException的不同在于,这个错误发生只在运行时需要加载对应的类不成功,而不是编译时发生。很多Java开发者很容易在这里把这两个错误搞混。

简单总结就是,NoClassDefFoundError发生在编译时对应的类可用,而运行时在Java的classpath路径中,对应的类不可用导致的错误。发生NoClassDefFoundError错误时,你能看到如下的错误日志:

<code class="hljs avrasm has-numbering" style="display: block; padding: 0px; color: inherit; box-sizing: border-box; font-family: 'Source Code Pro', monospace;font-size:undefined; white-space: pre; border-radius: 0px; word-wrap: normal; background: transparent;">Exception <span class="hljs-keyword" style="color: rgb(0, 0, 136); box-sizing: border-box;">in</span> thread <span class="hljs-string" style="color: rgb(0, 136, 0); box-sizing: border-box;">"main"</span> java<span class="hljs-preprocessor" style="color: rgb(68, 68, 68); box-sizing: border-box;">.lang</span><span class="hljs-preprocessor" style="color: rgb(68, 68, 68); box-sizing: border-box;">.NoClassDefFoundError</span></code><ul class="pre-numbering" style="box-sizing: border-box; position: absolute; width: 50px; top: 0px; left: 0px; margin: 0px; padding: 6px 0px 40px; border-right-width: 1px; border-right-style: solid; border-right-color: rgb(221, 221, 221); list-style: none; text-align: right; background-color: rgb(238, 238, 238);"><li style="box-sizing: border-box; padding: 0px 5px;">1</li><li></li></ul>

NoClassDefFoundError和ClassNotFoundException区别

我们经常被java.lang.ClassNotFoundException和java.lang.NoClassDefFoundError这两个错误迷惑不清,尽管他们都与Java classpath有关,但是他们完全不同。NoClassDefFoundError发生在JVM在动态运行时,根据你提供的类名,在classpath中找到对应的类进行加载,但当它找不到这个类时,就发生了java.lang.NoClassDefFoundError的错误,而ClassNotFoundException是在编译的时候在classpath中找不到对应的类而发生的错误。ClassNotFoundException比NoClassDefFoundError容易解决,是因为在编译时我们就知道错误发生,并且完全是由于环境的问题导致。而如果你在J2EE的环境下工作,并且得到NoClassDefFoundError的异常,而且对应的错误的类是确实存在的,这说明这个类对于类加载器来说,可能是不可见的。

怎么解决NoClassDefFoundError错误

根据前文,很明显NoClassDefFoundError的错误是因为在运行时类加载器在classpath下找不到需要加载的类,所以我们需要把对应的类加载到classpath中,或者检查为什么类在classpath中是不可用的,这个发生可能的原因如下:

  1. 对应的Class在java的classpath中不可用
  2. 你可能用jar命令运行你的程序,但类并没有在jar文件的manifest文件中的classpath属性中定义
  3. 可能程序的启动脚本覆盖了原来的classpath环境变量
  4. 因为NoClassDefFoundError是java.lang.LinkageError的一个子类,所以可能由于程序依赖的原生的类库不可用而导致
  5. 检查日志文件中是否有java.lang.ExceptionInInitializerError这样的错误,NoClassDefFoundError有可能是由于静态初始化失败导致的
  6. 如果你工作在J2EE的环境,有多个不同的类加载器,也可能导致NoClassDefFoundError

我发生错误的位置是在BaseApp 继承Application的类

写成如下:代替extends Application 运行即可

public class BaseApp extends android.support.multidex.MultiDexApplication
 
至此  我擦  只能说句我擦了   终于全部可以运行了。。。。。



### 解决方案概述 `java.lang.OutOfMemoryError: Java heap space` 是一种常见的错误,表明 JVM 的堆内存不足以支持当前操作。在 Android Studio 中,这种问题可能由多种因素引起,例如项目规模过大、依赖库过多或构建工具配置不当等。 以下是针对该问题的具体解决方法: --- #### 方法一:调整 Gradle 构建工具的堆内存大小 通过修改 `gradle.properties` 文件来增加 Gradle 的堆内存分配是一个常见且有效的解决方案[^2]。具体步骤如下: 1. 打开项目的根目录下的 `gradle.properties` 文件。 2. 添加以下内容以提高 Gradle 的 JVM 内存分配: ```properties org.gradle.jvmargs=-Xmx2048m -XX:MaxPermSize=512m -XX:+HeapDumpOnOutOfMemoryError -Dfile.encoding=UTF-8 ``` 这里的 `-Xmx2048m` 表示将最大堆内存设置为 2GB;可以根据实际硬件条件进一步调整。 --- #### 方法二:优化 Android Studio 的 JVM 配置 Android Studio 自身也有独立的 JVM 设置,可以通过调整其内存参数来缓解问题[^4]: 1. 编辑 Android Studio 的配置文件(路径因操作系统不同而异): - **Windows**: `%USERPROFILE%\.AndroidStudio<version>\config\studio.vmoptions` - **macOS**: `~/Library/Application Support/Google/AndroidStudio<version>/studio.vmoptions` - **Linux**: `~/.AndroidStudio<version>/config/studio.vmoptions` 2. 修改其中的关键参数,例如: ```properties -Xms512m -Xmx2048m -XX:MaxPermSize=512m -XX:ReservedCodeCacheSize=512m ``` 上述配置分别设置了最小堆内存 (`-Xms`) 和最大堆内存 (`-Xmx`) 大小。 --- #### 方法三:分析并减少内存占用 除了直接提升内存上限外,还可以尝试从源头解决问题,降低内存消耗[^3]: 1. **清理无用资源**:移除不必要的图片、视频或其他大型资产文件。 2. **启用增量构建**:确保启用了 Gradle 的增量构建功能,避免每次重新编译整个项目。 3. **禁用 Instant Run**:Instant Run 功能可能会导致额外的内存压力,在较旧版本中尤其明显。 4. **监控内存使用情况**:借助 Android Profiler 或其他性能分析工具定位具体的内存瓶颈。 --- #### 方法四:合理设置 JVM 参数 对于某些特定场景(如加载大量数据),可以手动调整 JVM 的堆内存参数[^5]: 1. 使用命令行启动应用时指定自定义参数: ```bash java -Xms512m -Xmx4g -XX:+UseG1GC YourApplicationClass ``` 此处 `-Xms` 定义初始堆大小,`-Xmx` 定义最大堆大小,`-XX:+UseG1GC` 启用 G1 垃圾回收算法。 2. 如果仍然频繁触发 GC,则考虑引入更高效的缓存策略或分批处理大数据集。 --- ### 总结 上述方法涵盖了从环境配置到代码层面的各种改进措施。优先推荐先调整 Gradle 和 Android Studio 的 JVM 参数,因为这是最简单快捷的方式。如果问题依旧存在,则需深入排查是否存在潜在的内存泄漏或者不合理的设计逻辑。 ```python # 示例 Python 脚本展示如何动态调整 JVM 参数(仅作参考) import subprocess def start_java_app_with_custom_jvm_args(app_class, min_heap="512m", max_heap="4g"): jvm_args = f"-Xms{min_heap} -Xmx{max_heap}" command = ["java", jvm_args, app_class] result = subprocess.run(command, capture_output=True, text=True) return result.stdout output = start_java_app_with_custom_jvm_args("YourAppMainClass") print(output) ```
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值