Grow heap (frag case) to 6.437MB for 1114126-byte allocation

本篇文章是对Grow heap (frag case) 堆内存过大的问题进行了详细的分析介绍,需要的朋友参考下

对于Android开发者来说虽然使用了可以自动管理内存的Java语言,但是对于内存管理不当,可能你的应用不断出现类似 INFO/dalvikvm-heap(10798): Grow heap (frag case) to 6.437MB for 1114126-byte allocation,而出现的
Grow heap
后面的值不断增加,接下来轻微则Android系统开始结束后台任务来增加不断增加的堆内存问题,最后可能直接出现OOM,同时有时候GC还可能出现GC
freed 0 objects / 0 bytes in
75ms这样的问题,对于Java的内存管理我们近期已经说到了,就上面这些问题Android123给大家做一个简单的分析。

1. 这里Grow heap (frag case) to 6.437MB for 1114126-byte allocation表示你一直在分配一个较大的对象,占用的堆内存达到了6.4MB。

2.
为什么会出现这样的问题,经过询问表示是因为分配了一个byte[]数组,需要以Blob方式写入SQLite数据库,而造成的这么大的单个对象出现,这
里Android开发网提醒大家,这是很危险的操作,对于不同固件和低RAM配置的设备随时都有OOM的危险,如果你真的需要往SQLite存储二进制,
这里可以采用分段的方式,将某个对象拆分为1MB或更小,分更多的段来存放,中间加一层拆分数据缓存层来解决比较好。

3. 同时每次构造单个较大对象前,可以通知gc准备收集,比如在执行需要耗操作前执行System.gc(); 防止OutOfMemoryError的发生,对于Java的内存溢出问题,今后我们会通过各种案例来讲解。

时间: 2024-11-20 21:25:06

Grow heap (frag case) to 6.437MB for 1114126-byte allocation的相关文章

关于解决VM heap的问题

<p> 今天弄个简单的图片显示程序</p> LinearLayout linearLayout =(LinearLayout)this.findViewById(R.id.LinearLayout1); for(int i=0;i<imagePath.length;i++) { img[i]=new ImageView(this); img[i].setImageResource(imagePath[i]); img[i].setPadding(5, 5, 5, 5); La

Echoprint系列--Android编译与调用

在Echoprint系列--编译中编译了源代码,这次将Echoprint移植到Android平台并測试识别歌曲功能. 一.编译库 1.环境准备 Android NDK,我的是android-ndk-r10e 改动源代码,把src中的.cxx的文件重命名为.cpp.把src文件夹重命名为jni Boost源代码.在PC上编译的时候也安装boost的,我的时boost_1_58_0,复制到jni文件夹 2.编写编译配置文件 打开源代码中的main.cpp,看到核心部分就是 codegen_respo

关于android 使用bitmap的OOM心得和解决方案

android开发,从2010年开始学习到现在的独立完成一个app,这漫长的四年,已经经历了很多次bug的折磨,无数次的加班训练.然而,自以为自己已经比较了解android了,却最近在一个项目上,因为oom而折腾了一个周,回到原地,认识了自己的不足,感觉自己是如此的菜鸟呀. 好了,不废话,大家在使用开发android的时候,很少会注意或者意识到释放内存的重要性,因为大家在使用过程中,涉及的图片资源不多,或者比较稳定,来回切换界面,图片也就那么几张或者使用的都是很小的图片,根本不会感觉到图片占用内

【BUG】&quot;main&quot; prio=5 tid=1 RUNNABLE

加载超大效果图导致内存不足(GC/ANR) 06-30 11:42:56.624: D/dalvikvm(16264): GC_CONCURRENT freed 1982K, 7% free 45372K/48775K, paused 1ms+3ms, total 50ms 06-30 11:42:57.469: D/DeviceTrackActivity(16264): onPause() 06-30 11:42:57.994: D/dalvikvm(16264): GC_CONCURRENT

如何分析Android的Log

首先,让我们看一看AndroidLog的格式.下面这段log是以所谓的long格式打印出来的.从前面Logcat的介绍中可以知道,long格式会把时间,标签等作为单独的一行显示. [ 12-09 21:39:35.510  396: 416 I/ActivityManager ] Start procnet.coollet.infzmreader:umengService_v1 for service net.coollet.infzmreader/com.umeng.message. Umen

【原创】LogCat信息演示Activity生命周期

界面如下:注意:这是在手机.竖屏状态下! (一)1个Activity     /**     * 7个方法     * 测试1个Activity的生命周期     *      * LogCat:     * 1.     * 启动之后:依次调用下面3个方法     * onCreate     * onStart     * onResume     *      * 按下手机或模拟器返回键:     * onPause     * onStop     * onDestroy     *  

【BUG】&amp;quot;main&amp;quot; prio=5 tid=1 RUNNABLE

载入超大效果图导致内存不足(GC/ANR) 06-30 11:42:56.624: D/dalvikvm(16264): GC_CONCURRENT freed 1982K, 7% free 45372K/48775K, paused 1ms+3ms, total 50ms 06-30 11:42:57.469: D/DeviceTrackActivity(16264): onPause() 06-30 11:42:57.994: D/dalvikvm(16264): GC_CONCURRENT

Android mediaplayer Couldn&#39;t open file on client side, trying server side

D/MediaPlayer( 2886): Couldn't open file on client side, trying server sideD/ActivityManager( 2624): checkComponentPermission() adjusting {pid,uid} to {2132,1013}E/MediaPlayerService( 2132): Couldn't open fd for content://media/external/audio/media/2

开启硬件加速 导致花屏问题 OpenGlRenderer 0x506 解决办法

(150114_17:08:32.461)I/dalvikvm-heap( 850): Grow heap (frag case) to 10.342MB for 2457616-byte allocation (150114_17:08:32.542)D/dalvikvm( 850): GC_FOR_ALLOC freed 20K, 25% free 10530K/14040K, paused 34ms, total 34ms (150114_17:08:32.551)D/dalvikvm(