Android中出现OOM情况的研究

简介:
  在Android中,一个Process 只能使用16M内存,要是超过了这个限定就会跳出这个异常。这样就要求我们要时刻想着开释资源。Java的回收工作是交给GC的,如何让GC能实时的回收已经不被用的对象,这个里面有许多技巧,各人可以google一下。 

  因为总内存的施用超过16M而引起OOM的情况,非常简单,我就不继续展开说。值当注意的是Bitmap在不用时,肯定是要recycle,不然OOM是非常容易出现的。 

  本文想跟大家一起讨论的是另外一种情况:明明还有许多内存,但是发生OOM了。 

  这类情况时常出现在生成Bitmap的时候。有兴趣的可以试一下,在一个函数里生成一个13M的int数组。 

  再该函数结束后,按理说这个int数组应该已经被开释了,或者说可以开释,这个13M的空间应该可以空出来,

  这个时候要是你继续生成一个10M的int数组是没有问题的,反而生成一个4M的Bitmap就会跳出OOM。这个就奇怪了,为啥子10M的int数组够空间,反而4M的Bitmap不够呢? 

  这个问题困扰好久,在网上,国外各大论坛搜刮了好久,一般关于OOM的解释和解决方法都是,如何让GC尽快回收的代码风格之类,并没有找出上面所说的情况的根源。 

  直到昨天在一个老外的blog上终于看到了这方面的解释,我理解后归纳如下: 

  在Android中: 

  1.一个进程的内存可以由2个部分组成:java 施用内存 ,C 施用内存 ,这两个内存的和必需小于16M,不然就会出现大家熟悉的OOM。 

  2.越发奇怪的是这个:一朝内存分配给Java后,以后这块内存纵然开释后,也只能给Java的施用,这个估计跟java虚拟机里把内存分成好几块进行缓存的原因有关,反正C就别想用到这块的内存了,所以要是Java突然占用了一个大块内存,纵然很快开释了: 

  C能施用的内存 = 16M - Java某一瞬间占用的最大内存。 

  而Bitmap的生成是通过malloc进行内存分配的,占用的是C的内存,这个也就说明了,上面所说的的4MBitmap无法生成的原因,因为在13M被Java用过后,剩下C能用的只有3M了。
相关文章
|
12天前
|
Android开发
Android Launcher研究(二)-----------Launcher为何物,究竟是干什么
Android Launcher研究(二)-----------Launcher为何物,究竟是干什么
15 2
|
7月前
|
JSON JavaScript 前端开发
Android 缩减、混淆处理和优化应用研究(二)
Android 缩减、混淆处理和优化应用研究(二)
|
7月前
|
IDE Java 编译器
Android 缩减、混淆处理和优化应用研究(一)
Android 缩减、混淆处理和优化应用研究(一)
|
监控 JavaScript 前端开发
|
12天前
|
Linux 开发工具 Android开发
Android Launcher研究(一)-----------图文详解手把手教你在Windows环
Android Launcher研究(一)-----------图文详解手把手教你在Windows环
21 0
|
12天前
|
定位技术 API 数据库
基于Android的在线移动电子导航系统的研究与实现(论文+源码)_kaic
基于Android的在线移动电子导航系统的研究与实现(论文+源码)_kaic
|
7月前
|
Ubuntu Linux Android开发
Android研究系列(1)
最近下班之后的研究基本上都放在了安卓和ios的研究之上,从原先的小米2s各种刷机各种刷ram,到下载大型单机游戏侠盗飞车大三基本上把安卓玩了个遍。不过也是很长时间没有玩手机这一层了,最近和同事聊起来安卓和ios,感觉其实ios 更像linux或者说ubuntu(自己用的ubuntu最多),而安卓更像wiondows,就从数据垃圾处理这一层来说,卸载windows的应用C盘必然会留下相应的数据垃圾,这一点不就是安卓的弊病么,windows越用越卡,安卓何尝不是。最近在刷ios,了解ios的更多信息,同时也欢迎各位给出批评指正。这一期的文章总共分为图片不知道图片多少篇,看自己研究到什么时候,什么
|
8月前
|
Java 开发工具 Maven
Android 编译 gradle 内存 OOM 解决之路(二)
Android 编译 gradle 内存 OOM 解决之路
|
8月前
|
Java Android开发
Android 编译 gradle 内存 OOM 解决之路(一)
Android 编译 gradle 内存 OOM 解决之路
|
前端开发 Java Linux
内存泄露,OOM,ANR ,Devik 进程,Framework原理,Activity 生成一个 view,Android 中的动画,SurfaceView和V
内存泄露,OOM,ANR ,Devik 进程,Framework原理,Activity 生成一个 view,Android 中的动画,SurfaceView和V
206 0