Question

0:000> !dumpheap -stat
total 1755874 objects
Statistics:
MT    Count    TotalSize Class Name
7b9b0c64        1           12 System.Windows.Forms.Layout.TableLayout+ColumnSpanComparer
....
7933303c    14006      4926456 System.Collections.Hashtable+bucket[]
65246e00      804      4982192 System.Data.RBTree`1+Node[[System.Int32, mscorlib]][]
054c55f0    44240      5662720 DevExpress.Utils.AppearanceObject
793040bc    98823      7613156 System.Object[]
793308ec   293700     55820016 System.String
002435f0    50315    138631888      Free
Total 1755874 objects

Fragmented blocks larger than 0.5 MB:
    Addr     Size      Followed by
15a195c8    0.8MB         15ae3950 System.Collections.ArrayList
15d81468    1.6MB         15f23708 System.String
15f23984    1.0MB         16029ae4 System.String
... about 7 more objects here
1ee51764    0.5MB         1eedbaa4 System.WeakReference
1f0df96c    2.4MB         1f34d4b0 System.String
1f3e1ca8    3.7MB         1f79afc4 System.WeakReference

Je l'ai lu sur épinglage et la fragmentation. Son me regardant fragmenté compte tenu de la quantité massive d'espace libre. Je suppose que je dois suivre maintenant vers le bas.

Pensées? modifier?

Était-ce utile?

La solution

Alors ... nous savons que nous avons un tas fragmenté. La question suivante est: ce qui cause la fragmentation? Ce qui est le maintien de ces objets libres d'être libéré? Les recommandations que j'ai lu est d'examiner les objets juste après l'espace libre:

  1. dumpheap -stat

  2. Dump la table de méthode de l'objet libre: dumpheap -MT 000db8e8

  3. Sélectionnez un objet libre dans la liste pour examiner de plus près: dumpobj 0x2003b0b0

  4. Enregistrer la taille de l'objet

  5. Vider le prochain objet après: dumpobj 0x2003b0b0 + 1000

  6. Trouvez l'objet qui représente une référence! Gcroot 0x2003b0b0 + 1000

  7. Vider le GCHandle de l'objet trouvé.

Je reçois habituellement dans cette trou de lapin, et ma connaissance limitée de l'API .NET échoue ici. Est-ce la bonne façon de déboguer le problème?

Jeff

Licencié sous: CC-BY-SA avec attribution
Non affilié à StackOverflow
scroll top