异常分析:Unable to execute dex: Cannot merge new index 71813 into a non-jumbo instruction!

解决dex合并错误
本文解决升级ADT和SDKTool后出现的dex合并错误问题,提供添加配置、清理工程等解决方案,并探讨了潜在的安装错误原因及长期代码膨胀的挑战。
在将ADT和SDK Tool升级到最新(分别是21.1和16.0.1)之后,我的一个工程(相对比较大)在编译并运行的时候,出现错误,Eclipse控制台输出如下信息:

      Unable to execute dex: Cannot merge new index 67208 into a non-jumbo instruction!
      Conversion to Dalvik format failed: Unable to execute dex: Cannot merge new index 67208 into a non-jumbo instruction!

      很多人在升级ADT和SDK Tool之后,都会遇到这个问题,只是错误信息中的数字不同而已。

      而且,我还发现一个现象:如果只是编译,但不生成APK,并不会出错;其实,从上面的错误信息中也可以看出一些线索 --- 它是在将jar文件转换成dex文件的时候出错的。

      网上给出的解决方案是,将dex.force.jumbo=true添加到project.properties文件中,然后清理工程,并重新编译。

      这个方法可以解决编译阶段问题,但是产生的APK在某些机器上不能安装(Installation error: INSTALL_FAILED_DEXOPT),针对这个问题的一个可能解释是:

      最新的ADT和SDK Tool在将jar转化成dex的时候,可能会合并类的代码,这将导致巨大的类;类中的每一个方法都分配有一个id,字节码中以id标识和调用方法;早期的Dalvik VM内部使用short类型变量来标识方法的id,最大值限制在65535;综合上述因素,代码在安装的时候,不能通过验证,所以安装失败。

      最新的Android可能已经解决了这个问题,但是更早的Android版本可能仍然存在此问题。

      因此,由于大量遗留机器的存在,这个问题是不能彻底解决的,一个临时的解决方案是:删掉没有实际使用的代码,或者使用ProGuard处理代码(可以减小代码体积)。

      一个不幸的推论是:随着一个软件功能的增加,代码的膨胀,APK包终将超出可以处理的范围,也许就是8M(指APK包里面的classes.dex).

      与此问题相关的两个讨论组是:

      https://code.google.com/p/android/issues/detail?id=40409

      https://groups.google.com/forum/?fromgroups=#!topic/adt-dev/tuLXN9GkVas

虽然给定引用未涉及 org.codehaus.gmaven:gmaven-plugin:1.5:execute (make new jar) 目标失败的相关内容,但一般来说,Maven 插件执行目标失败可从以下几个方面排查解决: ### 插件依赖问题 检查插件及其依赖是否能正确解析。可能是由于网络问题、Maven 仓库配置问题等导致插件或其依赖无法下载。可尝试清理本地 Maven 仓库中的相关缓存,再重新构建项目。缓存通常位于 `~/.m2/repository` 目录下,删除相关插件目录后重新构建。 ```bash rm -rf ~/.m2/repository/org/codehaus/gmaven/gmaven-plugin mvn clean install ``` ### 插件版本兼容性 确认使用的插件版本与项目的 Maven 版本、Java 版本等是否兼容。可以尝试升级或降级插件版本,在 `pom.xml` 中修改插件版本号: ```xml <plugin> <groupId>org.codehaus.gmaven</groupId> <artifactId>gmaven-plugin</artifactId> <version>其他兼容版本</version> </plugin> ``` ### 配置错误 检查 `pom.xml` 中插件的配置是否正确。确保插件的配置参数、执行目标等设置无误。 ```xml <plugin> <groupId>org.codehaus.gmaven</groupId> <artifactId>gmaven-plugin</artifactId> <version>1.5</version> <executions> <execution> <id>make new jar</id> <goals> <goal>execute</goal> </goals> <!-- 检查配置参数 --> <configuration> <!-- 配置内容 --> </configuration> </execution> </executions> </plugin> ``` ### 日志信息分析 使用 `-e` 和 `-X` 开关重新运行 Maven 命令,获取详细的错误堆栈信息和调试日志,根据日志中的具体错误信息进行针对性解决。 ```bash mvn -e -X org.codehaus.gmaven:gmaven-plugin:1.5:execute ```
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值