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
At the "CTO Training Camp" event hosted...
A few days ago, at a "copycat press conferen...
One of the things that netizens hate most when su...
Starting from the 21st, the entire city of Shenzh...
Author: Duan Yuechu The virtual world is a fascin...
On November 13, BlackBerry held a new product lau...
We live in the colorful 21st century. With the co...
In recent years, mobile Internet has developed ra...
“What has changed in our world?” 1. New brands: N...
Since 2016, countless knowledge payment platforms...
Yesterday, iOS WeChat updated to version 8.0.40, ...
Red envelopes are given out every year, but this ...
What is the AARRR model ? The AARRR model is also...
The o2o company I work for is a one-stop communit...
Many people must have heard of the story "A ...