Share via


memberInfoCacheCreation-MDA

Aktualisiert: November 2007

Der memberInfoCacheCreation-MDA (Managed Debugging Assistant, Assistent für verwaltetes Debuggen) wird aktiviert, wenn ein MemberInfo-Cache erstellt wird. Dies ist ein starkes Anzeichen für ein Programm, das ressourcenintensive Reflektionsfeatures verwendet.

Symptome

Das Workingset eines Programms wird vergrößert, weil das Programm ressourcenintensive Reflektionsfunktionen verwendet.

Ursache

Reflektionsvorgänge unter Verwendung von MemberInfo-Objekten werden als ressourcenintensiv betrachtet, weil hierbei Metadaten gelesen werden müssen, die in Seiten außerhalb des CPU-Cache gespeichert sind. Im Allgemeinen sind sie auch ein Anzeichen dafür, dass im Programm ein Szenario mit später Bindung verwendet wird.

Lösung

Sie können feststellen, an welchen Stellen im Programm Reflektion verwendet wird, indem Sie diesen MDA bereitstellen und den Code anschließend in einem Debugger ausführen oder einen Debugger an das Programm anhängen, wenn der MDA aktiviert wurde. Im Debugger erhalten Sie eine Stapelüberwachung, in der angezeigt wird, an welcher Stelle der MemberInfo-Cache erstellt wurde. Ausgehend von diesen Informationen können Sie ermitteln, an welcher Stelle das Programm Reflektion verwendet.

Die Lösung häng vom Zweck des Codes ab. Dieser MDA warnt Sie, dass im Programm ein Szenario mit später Bindung eingesetzt wird. Möglicherweise empfiehlt es sich, stattdessen ein Szenario mit früher Bindung einzusetzen oder die Leistung des Szenarios mit später Bindung zu untersuchen.

Auswirkungen auf die Laufzeit

Dieser MDA wird für jeden MemberInfo-Cache aktiviert, der erstellt wird. Die Auswirkungen auf die Leistung sind unwesentlich.

Ausgabe

Der MDA gibt eine Meldung aus, die angibt, dass ein MemberInfo-Cache erstellt wurde. Verwenden Sie einen Debugger, um eine Stapelüberwachung abzurufen, aus der ersichtlich ist, an welchen Stellen das Programm Reflektion verwendet.

Konfiguration

<mdaConfig>
  <assistants>
    <memberInfoCacheCreation/>
  </assistants>
</mdaConfig>

Beispiel

In diesem Beispielcode wird der memberInfoCacheCreation-MDA aktiviert.

using System;

public class Exe
{
    public static void Main()
    {
        typeof(object).GetMethods();
    }
}

Siehe auch

Konzepte

Diagnostizieren von Fehlern mit Assistenten für verwaltetes Debuggen

Referenz

MemberInfo