开发者

Diff b/w bitmap.recycle() and bitmap=null

I am in a situation where I have used a for loop to download a set of images and I am converting it into bitmap images. So in order to avoid OutOfMemory error, I am trying to recycle the bitmaps. But unfortunately I am running into another exception saying something like "View trying to use a recycled bitmap".

But still I am allowed to null the used bitmap by using bitmap=null. So my question is, will making my bitmap null help me in freeing up the used memory? or should I provide bitmap.recycle() 开发者_Go百科in some other part of my code?


Calling recycle() indicates to the system that you are finished using that resource and that the system may now free the unmanaged memory that it was using. Once you have disposed of a resource in this way, its behaviour is usually undefined (one would reasonably expect it to simply no longer work).

Setting the reference to null afterwards has two benefits:

  • You won't have stale references to objects that won't work when you try to use them
  • The garbage collector will know to clean up the managed side of the bitmap object, freeing even more memory


There is no guaranteed way to force a garbage collection, only a way to suggest one using System.gc(). Since the bitmaps pixel data lives in native memory outside of the dalvik heap, providing a native function (in this case recycle()) will give us the opportunity to clean up this pixel data for sure (eventually). Please note that when using recycle() there is not much more you can do with that bitmap.

The issue you are having is that you are calling recycle() on a bitmap, which you are still trying to use.

To answer your question, yes, setting bitmap to null after you have recycled it is a good idea, but it may also be redundant. Always try to recycle your bitmaps when you are done with them.


just call bitmap.recycle() on onStop method .............u will solve the problem ..

0

上一篇:

下一篇:

精彩评论

暂无评论...
验证码 换一张
取 消

最新问答

问答排行榜