Android: de mémoire sur une allocation d'octets (android.les graphiques.Bitmap)
J'ai Apporté mon appli en arrière dans la vue après un moment de repos dans le fond et j'ai remarqué qu'il est très lent et puis tout simplement pas de réponse. Alors j'ai vérifié logcat et je vois
"De mémoire sur un 557296-allocation d'octets". La dernière chose que j'ai fait avant mon application va inactivité a été ajouter plusieurs enregistrements à un couple de tables dans ma base de données. Cependant, la dernière ligne de mon logcat avant que la mémoire d'erreur a quelque chose à voir avec une image?..."android.les graphiques.Bitmap.createBitmap" . Je ne suis pas sûr de savoir comment commencer le suivi.
11-07 20:32:22.940: D/PMS(599): acquireWL(42e31570): PARTIAL_WAKE_LOCK CM_static 0x1 13857 10166
11-07 20:32:22.950: D/PMS(599): releaseWL(42e31570): PARTIAL_WAKE_LOCK CM_static 0x1
11-07 20:32:23.060: E/dalvikvm(16038): can't open /data/misc/app_oom.hprof: Permission denied
11-07 20:32:23.100: E/dalvikvm-heap(16038): hprofDumpHeap failed with result: -1
11-07 20:32:23.100: E/dalvikvm-heap(16038): After hprofDumpHeap for process
11-07 20:32:23.100: E/dalvikvm(16038): Out of memory: Heap Size=196608KB, Allocated=188196KB, Limit=196608KB, Proc Limit=196608KB
11-07 20:32:23.100: E/dalvikvm(16038): Extra info: Footprint=196512KB, Allowed Footprint=196608KB, Trimmed=2828KB
11-07 20:32:23.200: I/dalvikvm-heap(16038): Clamp target GC heap from 193.013MB to 192.000MB
11-07 20:32:23.200: I/dalvikvm-heap(16038): Forcing collection of SoftReferences for 557296-byte allocation
11-07 20:32:23.240: D/MtpDatabase(25526): sessionStarted
11-07 20:32:23.310: I/dalvikvm-heap(16038): Clamp target GC heap from 193.013MB to 192.000MB
11-07 20:32:23.310: E/dalvikvm-heap(16038): Out of memory on a 557296-byte allocation.
11-07 20:32:23.310: I/dalvikvm(16038): "main" prio=5 tid=1 RUNNABLE
11-07 20:32:23.310: I/dalvikvm(16038): | group="main" sCount=0 dsCount=0 obj=0x41f267e8 self=0x41f113b8
11-07 20:32:23.310: I/dalvikvm(16038): | sysTid=16038 nice=0 sched=0/0 cgrp=apps handle=1074839548
11-07 20:32:23.310: I/dalvikvm(16038): | state=R schedstat=( 0 0 0 ) utm=61459 stm=7538 core=3
11-07 20:32:23.310: I/dalvikvm(16038): at android.graphics.Bitmap.nativeCreate(Native Method)
11-07 20:32:23.310: I/dalvikvm(16038): at android.graphics.Bitmap.createBitmap(Bitmap.java:1041)
11-07 20:32:23.310: I/dalvikvm(16038): at android.graphics.Bitmap.createBitmap(Bitmap.java:983)
11-07 20:32:23.310: I/dalvikvm(16038): at android.view.View.buildDrawingCache(View.java:13312)
11-07 20:32:23.310: I/dalvikvm(16038): at android.view.View.getDrawingCache(View.java:13161)
11-07 20:32:23.310: I/dalvikvm(16038): at android.view.View.draw(View.java:13859)
11-07 20:32:23.310: I/dalvikvm(16038): at android.view.ViewGroup.drawChild(ViewGroup.java:3105)
11-07 20:32:23.310: I/dalvikvm(16038): at android.widget.ListView.drawChild(ListView.java:3590)
11-07 20:32:23.310: I/dalvikvm(16038): at android.view.ViewGroup.dispatchDraw(ViewGroup.java:2934)
11-07 20:32:23.310: I/dalvikvm(16038): at android.widget.AbsListView.dispatchDraw(AbsListView.java:2520)
11-07 20:32:23.310: I/dalvikvm(16038): at android.widget.ListView.dispatchDraw(ListView.java:3560)
11-07 20:32:23.310: I/dalvikvm(16038): at android.view.View.draw(View.java:14175)
11-07 20:32:23.310: I/dalvikvm(16038): at android.widget.AbsListView.draw(AbsListView.java:3993)
11-07 20:32:23.310: I/dalvikvm(16038): at android.view.View.draw(View.java:14053)
11-07 20:32:23.310: I/dalvikvm(16038): at android.view.ViewGroup.drawChild(ViewGroup.java:3105)
11-07 20:32:23.310: I/dalvikvm(16038): at android.view.ViewGroup.dispatchDraw(ViewGroup.java:2934)
11-07 20:32:23.310: I/dalvikvm(16038): at android.view.View.draw(View.java:14175)
11-07 20:32:23.310: I/dalvikvm(16038): at android.view.View.draw(View.java:14053)
11-07 20:32:23.310: I/dalvikvm(16038): at android.view.ViewGroup.drawChild(ViewGroup.java:3105)
11-07 20:32:23.310: I/dalvikvm(16038): at android.view.ViewGroup.dispatchDraw(ViewGroup.java:2934)
11-07 20:32:23.310: I/dalvikvm(16038): at android.view.View.draw(View.java:14051)
11-07 20:32:23.310: I/dalvikvm(16038): at android.view.ViewGroup.drawChild(ViewGroup.java:3105)
11-07 20:32:23.310: I/dalvikvm(16038): at android.view.ViewGroup.dispatchDraw(ViewGroup.java:2934)
11-07 20:32:23.310: I/dalvikvm(16038): at android.view.View.draw(View.java:14051)
11-07 20:32:23.310: I/dalvikvm(16038): at android.view.ViewGroup.drawChild(ViewGroup.java:3105)
11-07 20:32:23.310: I/dalvikvm(16038): at android.view.ViewGroup.dispatchDraw(ViewGroup.java:2934)
11-07 20:32:23.310: I/dalvikvm(16038): at android.view.View.draw(View.java:14175)
11-07 20:32:23.310: I/dalvikvm(16038): at android.widget.FrameLayout.draw(FrameLayout.java:467)
11-07 20:32:23.310: I/dalvikvm(16038): at com.android.internal.policy.impl.PhoneWindow$DecorView.draw(PhoneWindow.java:2312)
11-07 20:32:23.310: I/dalvikvm(16038): at android.view.ViewRootImpl.drawSoftware(ViewRootImpl.java:2761)
11-07 20:32:23.310: I/dalvikvm(16038): at android.view.ViewRootImpl.draw(ViewRootImpl.java:2674)
11-07 20:32:23.310: I/dalvikvm(16038): at android.view.ViewRootImpl.performDraw(ViewRootImpl.java:2491)
11-07 20:32:23.310: I/dalvikvm(16038): at android.view.ViewRootImpl.performTraversals(ViewRootImpl.java:2048)
11-07 20:32:23.310: I/dalvikvm(16038): at android.view.ViewRootImpl.doTraversal(ViewRootImpl.java:1119)
11-07 20:32:23.310: I/dalvikvm(16038): at android.view.ViewRootImpl$TraversalRunnable.run(ViewRootImpl.java:5849)
11-07 20:32:23.310: I/dalvikvm(16038): at android.view.Choreographer$CallbackRecord.run(Choreographer.java:786)
11-07 20:32:23.310: I/dalvikvm(16038): at android.view.Choreographer.doCallbacks(Choreographer.java:586)
11-07 20:32:23.310: I/dalvikvm(16038): at android.view.Choreographer.doFrame(Choreographer.java:546)
11-07 20:32:23.310: I/dalvikvm(16038): at android.view.Choreographer$FrameDisplayEventReceiver.run(Choreographer.java:771)
11-07 20:32:23.310: I/dalvikvm(16038): at android.os.Handler.handleCallback(Handler.java:730)
11-07 20:32:23.310: I/dalvikvm(16038): at android.os.Handler.dispatchMessage(Handler.java:92)
11-07 20:32:23.310: I/dalvikvm(16038): at android.os.Looper.loop(Looper.java:158)
11-07 20:32:23.310: I/dalvikvm(16038): at android.app.ActivityThread.main(ActivityThread.java:5789)
11-07 20:32:23.310: I/dalvikvm(16038): at java.lang.reflect.Method.invokeNative(Native Method)
11-07 20:32:23.310: I/dalvikvm(16038): at java.lang.reflect.Method.invoke(Method.java:525)
11-07 20:32:23.310: I/dalvikvm(16038): at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:1027)
11-07 20:32:23.310: I/dalvikvm(16038): at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:843)
11-07 20:32:23.310: I/dalvikvm(16038): at dalvik.system.NativeStart.main(Native Method)
11-07 20:32:23.310: E/dalvikvm-heap(16038): Generating hprof for process: com.test.myApp PID: 16038
Cette réponse dans le lien ici conduire à ma trouver mon fuites de mémoire: [stackoverflow.com/questions/1147172/... [1]: stackoverflow.com/questions/1147172/...
OriginalL'auteur Mike6679 | 2013-11-08
Vous devez vous connecter pour publier un commentaire.
Utilisez-vous des images dans votre application? Vous devez recycler des bitmaps à l'aide de bitmap.le recyclage(). Si vous n'avez pas de recycler vos bitmaps vous le risque d'une sortie de la mémoire d'exception.
Si vous avez des bitmaps je recommande de faire cette après ils sont utilisés:
Cela permettra d'assurer le bitmap est des ordures collectées.
Si vous n'avez pas les bitmaps, je recommande d'utiliser les outils fournis dans DDMS pour surveiller la taille de segment de mémoire. Mettre votre appareil en veille et enregistrer les modifications de l'application. J'ai résolu plusieurs de mémoire exceptions à l'aide de ces outils, et j'espère que vous pouvez pour.
Après de plus amples recherches sur ce, je crois que mon dernier commentaire n'est pas correct. Je ne veux pas simplement traiter les symptômes de mon problème mais le à la racine de mon problème, ce qui est un ou plusieurs fuites de mémoire. Ce lien ici : stackoverflow.com/questions/12041297/... traite en fait comment faire pour traquer vos fuites de mémoire dans Android et comment les éviter.
OriginalL'auteur vinnymac