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 t
just call bitmap.recycle() on onStop method .............u will solve the problem ..
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:
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.