Freigeben über


FunctionTailcall-Funktion

Aktualisiert: November 2007

Benachrichtigt den Profiler, dass die zurzeit ausgeführte Funktion im Begriff ist, einen Endeaufruf einer anderen Funktion durchzuführen.

Tipp

Die FunctionTailcall-Funktion ist in .NET Framework, Version 2.0, veraltet. Sie kann zwar weiter verwendet werden, es kommt jedoch zu Leistungeinbußen. Stattdessen wird die FunctionTailcall2 verwendet.

void 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 reservieren.

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

ICorProfilerInfo2::SetEnterLeaveFunctionHooks2-Methode

Weitere Ressourcen

Profilerstellung für globale statische Funktionen