我的应用在源代码的以下行中遇到OOM错误:image = BitmapFactory.decodeStream(assetManager.open(imgFilename));在导致应用因OOM错误而被终止的分配之前:(...)08-05 21:22:12.443: I/dalvikvm-heap(2319): Clamp target GC heap from 25.056MB to 24.000MB08-05 21:22:12.443: D/dalvikvm(2319): GC_FOR_MALLOC freed <1K, 50% free 2709K/5379K, external 18296K/19336K, paused 58ms08-05 21:22:14.513: D/dalvikvm(2319): GC_EXTERNAL_ALLOC freed <1K, 50% free 2709K/5379K, external 18296K/19336K, paused 101ms08-05 21:22:14.903: I/dalvikvm-heap(2319): Clamp target GC heap from 25.073MB to 24.000MB08-05 21:22:14.903: D/dalvikvm(2319): GC_FOR_MALLOC freed 0K, 50% free 2709K/5379K, external 18312K/19336K, paused 53ms08-05 21:22:22.843: D/ddm-heap(2319): Heap GC request08-05 21:22:22.963: I/dalvikvm-heap(2319): Clamp target GC heap from 25.073MB to 24.000MB08-05 21:22:22.963: D/dalvikvm(2319): threadid=1: still suspended after undo (sc=1 dc=1)08-05 21:22:22.963: D/dalvikvm(2319): GC_EXPLICIT freed 1K, 50% free 2710K/5379K, external 18312K/19336K, paused 116msDDMS报告有关堆状态的类似图片:Heap Size: 5.254 MBAllocated: 2.647 MBFree: 2.607 MB%Used: 50.38%#Objects 49,028 单步越过此行会导致OOM错误:08-05 21:26:04.783: D/dalvikvm(2319): GC_EXTERNAL_ALLOC freed <1K, 50% free 2710K/5379K, external 18312K/19336K, paused 57ms08-05 21:26:05.023: E/dalvikvm-heap(2319): 2097152-byte external allocation too large for this process.08-05 21:26:05.163: I/dalvikvm-heap(2319): Clamp target GC heap from 25.073MB to 24.000MB08-05 21:26:05.163: E/GraphicsJNI(2319): VM won't let us allocate 2097152 bytes08-05 21:26:05.163: D/dalvikvm(2319): GC_FOR_MALLOC freed 0K, 50% free 2710K/5379K, external 18312K/19336K, paused 30ms08-05 21:26:05.283: D/skia(2319): --- decoder->decode returned false在Windows上,“ imgFileName”引用的文件的大小据报告为<400K。那么,为什么BitmapFactory.decodeStream尝试分配2MB?当似乎有足够的可用空间时,为什么会出现OOM错误?这个应用程式的目标是Android 2.2以上版本。提前致谢!
4 回答
- 4 回答
- 0 关注
- 712 浏览
添加回答
举报
0/150
提交
取消