Freigeben über


FunctionLeave-Funktion

Benachrichtigt den Profiler, dass eine Funktion im Begriff ist, zum Aufrufer zurückzukehren.

HinweisHinweis

Die FunctionLeave-Funktion ist in .NET Framework 2.0 veraltet.Sie kann zwar weiter verwendet werden, es kommt jedoch zu Leistungseinbußen.Verwenden Sie stattdessen die FunctionLeave2-Funktion.

void __stdcall FunctionLeave (
    [in] FunctionID funcID
);

Parameter

  • funcID
    [in] Der Bezeichner der Funktion, die zurückkehrt.

Hinweise

Die FunctionLeave-Funktion ist ein Rückruf; Sie müssen sie implementieren. Die Implementierung muss das __declspec(naked)-Speicherklassenattribut verwenden.

Das Ausführungsmodul speichert vor dem Aufrufen dieser Funktion keine Register.

  • Beim Eintritt müssen Sie alle verwendeten Register speichern, auch die Register in der Gleitkommaeinheit (Floating-Point Unit, FPU).

  • Beim Beenden müssen Sie den Stapel wiederherstellen, indem Sie alle Parameter, die vom Aufrufer verschoben wurden, wieder abholen.

Die Implementierung von FunctionLeave sollte nicht blockieren, da dies die Garbage Collection verzögert. Die Implementierung sollte nicht versuchen, eine Garbage Collection durchzuführen, weil sich der Stapel möglicherweise nicht in einem für die Garbage Collection geeigneten Zustand befindet. Wenn eine Garbage Collection versucht wird, ist die Laufzeit blockiert, bis FunctionLeave zurückkehrt.

Außerdem darf die FunctionLeave-Funktion keinen verwalteten Code aufrufen und keinen verwalteten Speicher belegen.

Anforderungen

Plattformen: siehe Systemanforderungen für .NET Framework.

Header: CorProf.idl

Bibliothek: CorGuids.lib

.NET Framework-Versionen: 1.1, 1.0

Siehe auch

Referenz

FunctionEnter2-Funktion

FunctionLeave2-Funktion

FunctionTailcall2-Funktion

ICorProfilerInfo2::SetEnterLeaveFunctionHooks2-Methode

Weitere Ressourcen

Profilerstellung für globale statische Funktionen

Änderungsprotokoll

Datum

Versionsgeschichte

Grund

Oktober 2010

__stdcall zur Syntax hinzugefügt.

Kundenfeedback.