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

更多相关文章

  1. Android(安卓)ListView详解
  2. android实现桌面icon未读信息图标(类似与iPhone的badge)
  3. Android:SQLite数据库
  4. Android的sdk下载问题
  5. android studio 使用系统源码编译出来的api
  6. Android中半透明Activity效果另法
  7. 软键盘常用控制方法
  8. Android(安卓)Input(一)-相关模块初始化
  9. Android性能优化一些方法

随机推荐

  1. android网游开发之socket的简单设计和实
  2. Android平台上关于IM的实践总结
  3. Android(安卓)摇一摇开发——灵敏度优化
  4. Android单位区别与转化
  5. Android(安卓)屏幕尺寸适配大全
  6. 安卓开发中调用WebService实例
  7. android 优秀源码
  8. Android几种常见的多渠道(批量)打包方式
  9. Android中的广播机制(一)----- 接收广播
  10. 高德地图Android错误码1008、32和7;错误提