« Programmation C++/Conventions d'appel » : différence entre les versions

Un livre de Wikilivres.
Contenu supprimé Contenu ajouté
m Formatage, ajout de code
Aucun résumé des modifications
Ligne 1 : Ligne 1 :
{{Programmation C++}}
<noinclude>{{Programmation C++}}</noinclude>


== Convention d'appel ==
== Convention d'appel ==
Ligne 74 : Ligne 74 :
*{{en}} [http://en.wikipedia.org/wiki/Calling_convention Calling Convention]
*{{en}} [http://en.wikipedia.org/wiki/Calling_convention Calling Convention]
*{{en}} [http://www.hackcraft.net/cpp/MSCallingConventions/ Calling Conventions in Microsoft Visual C++]
*{{en}} [http://www.hackcraft.net/cpp/MSCallingConventions/ Calling Conventions in Microsoft Visual C++]

[[Catégorie:Programmation C++ (livre)]]

Version du 27 août 2017 à 23:41

Convention d'appel

Une convention d'appel à une fonction définit la manière d'appeler une fonction. La manière varie selon le langage de programmation, le compilateur, et parfois l'architecture du processeur cible.

En C++ la convention d'appel définit les points suivants :

  • l'ordre d'empilage des paramètres (à partir du premier, ou du dernier),
  • passage de certains paramètres dans les registres,
  • appel avec une adresse longue ou courte (selon la localisation en mémoire de la fonction),
  • désempilage des paramètres effectué par la fonction appelée ou le code appelant,
  • méthode de récupération de la valeur retournée.

Pour l'avant dernier point, le désempilage des paramètres est toujours effectué par le code appelant lorsque la fonction a un nombre variable d'arguments, car seul le code appelant connait assuremment le nombre de paramètres qu'il a empilé.

Conventions d'appels sous Windows

Attention: cette section sort du cadre du C++ standard et est spécifique à des développements sous Windows. Ces conventions d'appels n'existent pas sous UNIX et Linux.

Spécifier la convention d'appel

La convention d'appel est spécifiée juste avant le nom de la fonction. Parmi les conventions d'appel possibles :

  • __cdecl : Convention d'appel par défaut du C et du C++ quand la fonction est définie en dehors de toute classe, ou comporte un nombre variable d'arguments,
  • __stdcall : Convention d'appel utilisé par l'API Windows,
  • __fastcall : Passage de certains paramètres dans les registres,
  • thiscall : Convention d'appel utilisée implicitement par défaut par les fonctions définies dans une classe car il ajoute un paramètre supplémentaire : la référence à l'objet this. Ce mot clé ne peut être utilisé.
  • ...

Différences entre les conventions d'appel

Convention Paramètres dans les registres Empilage des paramètres Dépilage des paramètres
__cdecl aucun de droite à gauche par le code appelant
__stdcall aucun de droite à gauche par la fonction appelée
__fastcall les 2 premiers arguments de taille inférieure à 32 bits de droite à gauche par la fonction appelée
thiscall aucun de droite à gauche par la fonction appelée


Si la convention d'appel utilisée par le code appelant ne correspond pas à celui de la fonction appelée, la fonction ne comprend pas l'appel effectué et peut causer des dégats.

Nommage des fonctions

Pour éviter le problème et d'autres lors de l'édition de liens avec les librairies externes (extension .dll sous Windows, .so sous Unix/Linux), le compilateur nomme les fonctions selon les critères suivants :

  • Nom de la fonction,
  • Type des arguments,
  • Convention d'appel utilisée,
  • Type des exceptions lancées,
  • Nom de la classe où se situe la fonction.

Chaque compilateur utilise un nommage différent. Il est donc difficile d'utiliser une librairie qui n'a pas été compilée avec le même compilateur que l'application l'utilisant.

Liens