Partager via


FunctionEnter (fonction)

Informe le profileur que le contrôle est passé à une fonction.

RemarqueRemarque

La fonction FunctionEnter est déconseillée dans le .NET Framework version 2.0 et son utilisation peut entraîner une altération des performances.Utilisez à la place la fonction FunctionEnter2.

void __stdcall FunctionEnter (
    [in]  FunctionID funcID
);

Paramètres

  • funcID
    [in] Identificateur de la fonction à laquelle le contrôle est passé.

Notes

La fonction FunctionEnter est un rappel ; vous devez l'implémenter. L'implémentation doit utiliser l'attribut de classe de stockage __declspec (naked).

Le moteur d'exécution n'enregistre aucun registre avant d'appeler cette fonction.

  • À l'entrée, vous devez enregistrer tous les registres que vous utilisez, y compris ceux de l'unité en virgule flottante.

  • À la sortie, vous devez restaurer la pile en dépilant tous les paramètres qui ont fait l'objet d'un push par son appelant.

L'implémentation de FunctionEnter ne doit pas bloquer, car cela diffèrerait le garbage collection. L'implémentation ne doit pas tenter de garbage collection, car la pile n'est peut-être pas dans un état de garbage collection convivial. En cas de tentative de garbage collection, le runtime procède à un blocage jusqu'à ce que FunctionEnter soit retourné.

De plus, la fonction FunctionEnter ne doit pas effectuer d'appels dans du code managé, ni générer de quelque manière que ce soit une allocation de mémoire managée.

Configuration requise

Plateformes : consultez Configuration requise du .NET Framework.

En-tête : Corprof.idl

Bibliothèque : CorGuids.lib

Versions du .NET Framework : 1.1, 1.0

Voir aussi

Référence

FunctionEnter2 (fonction)

FunctionLeave2 (fonction)

FunctionTailcall2 (fonction)

ICorProfilerInfo2::SetEnterLeaveFunctionHooks2, méthode

Autres ressources

Fonctions statiques globales du profilage

Historique des modifications

Date

Historique

Motif

Octobre 2010

Ajouté __stdcall à la syntaxe.

Commentaires client.