Partager via


Appel de fonctions de la DLL à partir d'applications Visual Basic

Pour que des applications Visual Basic (ou des applications écrites dans d'autres langages tels que Pascal ou Fortran) appellent des fonctions dans une DLL C/C++, les fonctions doivent être exportées à l'aide de la convention d'appel correcte sans la décoration de noms effectuée par le compilateur.

__stdcall crée la convention d'appel correcte pour la fonction (la fonction appelée nettoie le pile et les paramètres sont passés de droite à gauche) mais décore le nom de la fonction différemment. Donc, quand le mot clé __declspec(dllexport) est appliqué à une fonction exportée d'une DLL, le nom décoré est exporté également.

La décoration de nom __stdcall fait précéder le nom du symbole d'un trait de soulignement (_) et annexe au symbole arobase (@) suivi du nombre d'octets dans la liste d'arguments (l'espace de pile requis). Lorsqu'elle est déclarée en tant que :

int __stdcall func (int a, double b)

la fonction est alors décorée de la manière suivante :

_func@12

La convention d'appel C (__cdecl) décore le nom en tant que _func.

Pour obtenir le nom décoré, utilisez /MAP. L'utilisation du mot clé __declspec(dllexport) produit l'effet suivant :

  • Si la fonction est exportée à l'aide de la convention d'appel C (_cdecl), elle supprime le trait de soulignement de début (_) quand le nom est exporté.

  • Si la fonction exportée n'utilise pas la convention d'appel C (par exemple, __stdcall), elle exporte le nom décoré.

Comme il n'existe aucun moyen de substituer les cas où le nettoyage de pile se produit, vous devez utiliser __stdcall. Pour supprimer la décoration des noms au moyen de __stdcall, vous devez spécifier les noms à l'aide d'alias dans la section EXPORTS du fichier .def. Cette approche est illustrée ci-dessous pour la déclaration de fonction suivante :

int  __stdcall MyFunc (int a, double b);
void __stdcall InitCode (void);

Dans le fichier .DEF :

EXPORTS
   MYFUNC=_MyFunc@12
   INITCODE=_InitCode@0

Pour que les DLL puissent être appelées par des programmes écrits en Visual Basic, la technique des alias décrite dans cette rubrique est nécessaire dans le fichier .def. Si l'alias est utilisé dans le programme Visual Basic, l'utilisation des alias dans le fichier .def n'est pas nécessaire. Elle peut être intégrée dans le programme Visual Basic par l'ajout d'une clause d'alias à l'instruction Declare.

Sur quels éléments souhaitez-vous obtenir des informations supplémentaires ?

Voir aussi

Concepts

DLL en Visual C++