解决“Cannot merge new index 67208 into a non-jumbo instruction”的问题

本文介绍了解决Android项目中因dex指令合并导致的编译错误方法。通过在project.properties文件中添加特定配置,并结合代码精简或使用ProGuard等手段减少dex文件大小,以应对早期Android版本的限制。

在将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

要将 `develop` 分支合并到 `qxh-graph` 分支,可以按照以下步骤操作: ### 1. 切换到目标分支 qxh-graph 首先确保你当前所在的分支是 `qxh-graph`。如果不是,请使用以下命令切换分支: ```bash git checkout qxh-graph ``` ### 2. 拉取最新代码(可选) 在合并之前,建议先拉取远程仓库的最新代码,以确保本地分支是最新的: ```bash git pull origin qxh-graph ``` ### 3. 合并 develop 分支到 qxh-graph 使用 `git merge` 命令将 `develop` 分支合并到 `qxh-graph` 分支: ```bash git merge develop ``` 如果你希望强制创建一个合并提交(即使可以进行 fast-forward 合并),可以使用 `--no-ff` 参数: ```bash git merge --no-ff develop ``` 这种方式会在合并时创建一个新的提交,保留合并的历史记录,适用于需要明确记录合并操作的场景 [^3]。 ### 4. 解决冲突(如果有) 如果 Git 在合并过程中检测到冲突,它会提示哪些文件存在冲突。你需要手动打开这些文件并解决冲突。冲突区域通常会被标记为: ```plaintext <<<<<<< HEAD // 当前分支的内容 ======= // 要合并的分支内容 >>>>>>> develop ``` 编辑文件,删除冲突标记,并保留最终想要的代码。保存后使用以下命令标记冲突已解决: ```bash git add <filename> ``` 然后继续完成合并: ```bash git commit ``` ### 5. 推送合并后的分支到远程仓库 完成合并并解决所有冲突后,将更新推送到远程仓库: ```bash git push origin qxh-graph ``` ### 6. 可选:使用 `--squash` 进行压缩合并 如果你希望将 `develop` 分支的所有更改压缩成一个单独的提交应用到 `qxh-graph` 分支上,可以使用 `--squash` 参数: ```bash git merge --squash develop ``` 该命令不会立即创建提交,而是将所有更改放入暂存区,你可以通过一次提交来完成合并: ```bash git commit -m "Merge develop into qxh-graph as a single commit" ``` 这种方式适合你希望简化提交历史的场景 [^2]。 --- ###
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值