似乎一些旧的Android操作系统(甚至是最新的)都对每个应用可以容纳的代码量有限制.
正如我发现,限制是在一个名为“LinearAlloc”的缓冲区上.
在2.2或2.3之间,大概是5-8 MB,我认为是其他的16或更多.
问题
如果您的代码太大(应用可以达到此状态),您将无法在旧设备上安装该应用程序,从而获得下一个错误(也报告为here):
Installation error: INSTALL_Failed_DEXOPT Please check logcat output for more details. Launch canceled!
我发现了什么
一个解决方案是尽可能地删除尽可能多的代码和库,但在一些巨大的项目上,这样的事情很难做到.
我发现下一个链接谈论Facebook如何解决这个问题,以某种方式增加限制:
> http://www.slashgear.com/how-facebook-fixed-its-gingerbread-dalvik-problem-04272478/
> http://arstechnica.com/business/2013/03/how-facebook-dug-deep-within-android-to-fix-its-mobile-app/
> https://www.facebook.com/notes/facebook-engineering/under-the-hood-dalvik-patch-for-facebook-for-android/10151345597798920
http://android-developers.blogspot.co.il/2011/07/custom-class-loading-in-dalvik.html
问题
Facebook做了如何做?
有可能在其他方面克服这个吗?
对于较新版本的Android版本有什么限制?
其他巨大的应用程序(和游戏)如何处理这个问题?他们把代码放入C/C++吗?
解决方法
> https://code.google.com/p/android/issues/detail?id=7147#c6
> https://code.google.com/p/android/issues/detail?id=20814#c6
在FB / Google文章中描述的不做任何事情和多重dex方法之间的中间位置是使用像ProGuard这样的工具来删除对Java级别的未使用代码的引用.看到:
> http://proguard.sourceforge.net/
> http://developer.android.com/tools/help/proguard.html