Have you ever felt that the available memory of your Android phone keeps decreasing after you turn it on? A big part of the reason is because of memory leakage. This leaked memory cannot be recycled, so the available memory is getting less and less; What is a memory leak? GC cannot recycle the object that should have been recycled, and this object causes a memory leak. 1. Forget to recycle Bitmap after use, because the implementation of Bitmap calls the Native method through JNI, and the GC mechanism cannot normally recycle the memory space requested by Bitmap (this was the case before API10, and then it was allocated in the Heap, but in order to be compatible with the old version... calling recycled explicitly can also allow GC to recycle faster); How should Bitmap be recycled?
Next, let's talk about two more common memory leaks. You can expand on these two.
Is this very common? You may also write it like this (encapsulating it has the same meaning, as long as you reference the current activity). You may want to ask, is there any problem here? The problem is that if the user presses the back key before the Toast disappears, this Activity will cause a memory leak. Reason? Toast holds the current Activity, which prevents the Activity from being destroyed by GC. Solution: Let Toast hold ApplicationContext; in fact, as long as it is not Layout, Context can use ApplicationContext; By the way, here's a little tip: In non-Activity, you cannot directly get Context using getContext. You need to rely on Context to get resources. In this case, you can consider maintaining a global Context in your own Application for classes that cannot directly get Context, saving the need to pass parameters around (ApplicationContext is not recommended for views)
Another common... memory leak
Is there a problem here? Are you kidding me? Create a new thread in the Activity to make a network request. If the thread is not finished and the user presses the back key, the memory leak will also occur. Reason: The Thread is an anonymous inner class, so it will implicitly hold the outer class (here is Activity) Solutions: Various; do not use anonymous inner classes, or maintain a thread pool or a thread queue for the entire application. The latter two methods make the thread independent of the Activity to avoid memory leaks. Context is needed in many places such as resource acquisition, and anonymous inner classes are used in many places, which leads to a great memory leak risk here, but many friends may not have noticed it. I hope this article can give you some inspiration. |
<<: Simplify the framework for switching between PageView and TabView
>>: When developing mobile apps, you should avoid these 5 details
On the 25th local time, an Azerbaijan Airlines pa...
Caocao talks about movies: a one-stop guide to mo...
As an App marketer or developer, competitor track...
December 16, 2021 "50 Days Countdown to Wint...
Since the opening of the Winter Olympics, all com...
The author shares his thoughts and experiences on...
With the continuous development of the Internet, ...
Yes, when you see this title, you must think of t...
If we were to transform into an ant-sized creatur...
In rural areas, many farmers are forced to work i...
[[235144]] Last week, my colleagues and I had a q...