1. Fuite de mémoire causée par un singleton. , En raison des caractéristiques statiques du singleton, son cycle de vie est le même que le cycle de vie de l'application. Par conséquent, si un objet n'est plus nécessaire, si l'objet singleton a une référence à l'objet, le l’objet ne peut pas être recyclé normalement.
Solution : Le cycle de vie du singleton est aussi long que l'application pour éviter les fuites mémoire.
// 使用了单例模式 public class AppManager { private static AppManager instance; private Context context; private AppManager(Context context) { this.context = context; } public static AppManager getInstance(Context context) { if (instance != null) { instance = new AppManager(context); } return instance; } }
2. Fuite de mémoire lors de l'utilisation du conteneur, La fuite de mémoire fait référence au moment où le code suivant sans rapport avec le vecteur est exécuté une fois l'opération vectorielle terminée, s'il se produit pendant Lors des opérations GC, cette série d'objets ne peut pas être recyclée, et la fuite de mémoire ici peut être de courte durée, car ces objets peuvent toujours être recyclés après l'exécution de l'intégralité de la méthode method().
La solution est très simple, il suffit d'attribuer manuellement la valeur à null :
void method(){ Vector vector = new Vector(); for (int i = 1; i<100; i++) { Object object = new Object(); vector.add(object); object = null; } //...对v的操作 vector = null; //...与v无关的其他操作 }
Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!