android decode bitmap,Android:BitmapFactory.decodeStream()

我的应用在源代码的以下行中遇到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.000MB

08-05 21:22:12.443: D/dalvikvm(2319): GC_FOR_MALLOC freed <1K, 50% free 2709K/5379K, external 18296K/19336K, paused 58ms

08-05 21:22:14.513: D/dalvikvm(2319): GC_EXTERNAL_ALLOC freed <1K, 50% free 2709K/5379K, external 18296K/19336K, paused 101ms

08-05 21:22:14.903: I/dalvikvm-heap(2319): Clamp target GC heap from 25.073MB to 24.000MB

08-05 21:22:14.903: D/dalvikvm(2319): GC_FOR_MALLOC freed 0K, 50% free 2709K/5379K, external 18312K/19336K, paused 53ms

08-05 21:22:22.843: D/ddm-heap(2319): Heap GC request

08-05 21:22:22.963: I/dalvikvm-heap(2319): Clamp target GC heap from 25.073MB to 24.000MB

08-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 116ms

DDMS报告有关堆状态的类似图片:

Heap Size:  5.254 MB

Allocated:  2.647 MB

Free:   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 57ms

08-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.000MB

08-05 21:26:05.163: E/GraphicsJNI(2319): VM won't let us allocate 2097152 bytes

08-05 21:26:05.163: D/dalvikvm(2319): GC_FOR_MALLOC freed 0K, 50% free 2710K/5379K, external 18312K/19336K, paused 30ms

08-05 21:26:05.283: D/skia(2319): --- decoder->decode returned false

在Windows上,“ imgFileName”引用的文件的大小据报告为<400K。那么,为什么BitmapFactory.decodeStream尝试分配2MB?

当似乎有足够的可用空间时,为什么会出现OOM错误?

这个应用程式的目标是Android 2.2以上版本。

提前致谢!

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值