FunctionTailcall-Funktion
Benachrichtigt den Profiler, dass die zurzeit ausgeführte Funktion im Begriff ist, einen Endeaufruf einer anderen Funktion durchzuführen.
Hinweis |
---|
Die FunctionTailcall-Funktion ist in .NET Framework, Version 2.0, veraltet.Sie kann zwar weiter verwendet werden, es kommt jedoch zu Leistungseinbußen.Stattdessen wird die FunctionTailcall2 verwendet. |
void __stdcall FunctionTailcall (
[in] FunctionID funcID
);
Parameter
- funcID
[in] Der Bezeichner der aktuell ausgeführten Funktion, die im Begriff ist, einen Endeaufruf durchzuführen.
Hinweise
Die Zielfunktion des Endeaufrufs verwendet den aktuellen Stapelrahmen und kehrt direkt zu dem Aufrufer der Funktion zurück, die den Endeaufruf ausgeführt hat. Dies bedeutet, dass für eine Funktion, die das Ziel eines Endeaufrufs ist, kein FunctionLeave-Rückruf ausgegeben wird.
Die FunctionTailcall-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 FunctionTailcall 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 FunctionTailcall zurückkehrt.
Außerdem darf die FunctionTailcall-Funktion keinen verwalteten Code aufrufen und keinen verwalteten Speicher verwalten.
Anforderungen
Plattformen: siehe Systemanforderungen für .NET Framework.
Header: CorProf.idl
Bibliothek: CorGuids.lib
.NET Framework-Versionen: 1.1, 1.0
Siehe auch
Referenz
ICorProfilerInfo2::SetEnterLeaveFunctionHooks2-Methode
Weitere Ressourcen
Profilerstellung für globale statische Funktionen
Änderungsprotokoll
Datum |
Versionsgeschichte |
Grund |
---|---|---|
Oktober 2010 |
__stdcall zur Syntax hinzugefügt. |
Kundenfeedback. |