现象:安装APK时报INSTALL_FAILED_DEXOPT的错误,如果在eclipse中看log会有LinearAlloc exceeded capacity的异常
原因:
1.INSTALL_FAILED_DEXOPT
最新的ADT和android SDK在将jar文件生成dex文件时会合并类,为了标识类中的每一个方法,为每一个方法分配一个id,早期的android VM指令集使用short类型id,最多可以标识65536个方法,因此如果App中包含的类超过了这个限制,就会直接报错,实际上当方法数在60000左右就可能无法通过验证了
2.LinearAlloc exceeded capacity
这个问题的原因也是由于App中的方法数过多导致的,android2.3以下版本的LinearAllocbuffer的大小是5M,这个容量与class.dex的大小无关
安装APK后会执行dexopt的操作,这个操作会检验dex中的指令集和App的方法数,如果超过限制就会报错,还会试着将这些方法读入android虚拟机中进行检验,这时就要用到LieanerAlloc buffer,如果方法总的容量大于这个限制就会报LinearAlloc exceeded capacity的错误,通常方法数在56000左右都可以放入LinearAlloc buffer中
解决方法:精简apk中的方法,去掉无用的jar包引用