Est-ce mon tas fragmenté
-
22-08-2019 - |
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?
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:
-
dumpheap -stat
-
Dump la table de méthode de l'objet libre: dumpheap -MT 000db8e8
-
Sélectionnez un objet libre dans la liste pour examiner de plus près: dumpobj 0x2003b0b0
-
Enregistrer la taille de l'objet
-
Vider le prochain objet après: dumpobj 0x2003b0b0 + 1000
-
Trouvez l'objet qui représente une référence! Gcroot 0x2003b0b0 + 1000
-
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