Freigeben über


gcManagedToUnmanaged-MDA

Aktualisiert: November 2007

Der gcManagedToUnmanaged-MDA (Managed Debugging Assistant, Assistent für verwaltetes Debuggen) veranlasst bei jedem Übergang eines Threads von verwaltetem zu nicht verwaltetem Code eine Garbage Collection.

Symptome

Eine nicht verwaltete Benutzerkomponente löst bei dem Versuch, ein für COM verfügbar gemachtes verwaltetes Objekt zu verwenden, eine Zugriffsverletzung aus. Das COM-Objekt wurde scheinbar freigegeben. Die Zugriffsverletzung ist nicht deterministisch.

Ursache

Wenn eine nicht verwaltete Komponente keine korrekte Verweiszählung für ein verwaltetes COM-Objekt durchführt, wird das für COM verfügbar gemachte verwaltete Objekt unter Umständen schon einer Garbage Collection unterzogen, während die nicht verwaltete Komponente noch über einen Verweis auf dieses Objekt verfügt. Bei der Garbage Collection wird von der CLR Release aufgerufen. Wenn die Benutzerkomponente das Objekt also vor dem Ausführen der Garbage Collection verwendet, wurde es noch nicht der Garbage Collection unterzogen. Dies ist die Ursache des Nichtdeterminiertheit.

Lösung

Durch das Aktivieren dieses Assistenten verringert sich die Zeit zwischen der Freigabe zur Garbage Collection und dem Aufruf von Release. So kann besser ermittelt werden, welche nicht verwaltete Komponente zuerst versucht, auf das der Garbage Collection unterzogene Objekt zuzugreifen.

Auswirkungen auf die Laufzeit

Bei jedem Übergang eines Threads von verwaltetem zu nicht verwaltetem Code wird eine Garbage Collection veranlasst.

Ausgabe

Dieser MDA erzeugt keine Ausgabe.

Konfiguration

<mdaConfig>
  <assistants>
    <gcManagedToUnmanaged/>
  </assistants>
</mdaConfig>

Siehe auch

Konzepte

Diagnostizieren von Fehlern mit Assistenten für verwaltetes Debuggen

Übersicht über das Interop-Marshalling

Referenz

MarshalAsAttribute

gcUnmanagedToManaged-MDA

Weitere Ressourcen

Interoperabilität