Partager via


CorPinvokeMap

Mise à jour : novembre 2007

Spécifie les options d'un appel PInvoke.

typedef enum  CorPinvokeMap {
        
    pmNoMangle          = 0x0001,
        
    pmCharSetMask       = 0x0006,
    pmCharSetNotSpec    = 0x0000,
    pmCharSetAnsi       = 0x0002,
    pmCharSetUnicode    = 0x0004,
    pmCharSetAuto       = 0x0006,
        
    pmBestFitUseAssem   = 0x0000,
    pmBestFitEnabled    = 0x0010,
    pmBestFitDisabled   = 0x0020,
    pmBestFitMask       = 0x0030,
        
    pmThrowOnUnmappableCharUseAssem   = 0x0000,
    pmThrowOnUnmappableCharEnabled    = 0x1000,
    pmThrowOnUnmappableCharDisabled   = 0x2000,
    pmThrowOnUnmappableCharMask       = 0x3000,
        
    pmSupportsLastError = 0x0040, 
        
    pmCallConvMask      = 0x0700,
    pmCallConvWinapi    = 0x0100,
    pmCallConvCdecl     = 0x0200,
    pmCallConvStdcall   = 0x0300,
    pmCallConvThiscall  = 0x0400,
    pmCallConvFastcall  = 0x0500,

    pmMaxValue          = 0xFFFF
        
} CorPinvokeMap;

Membres

Membre

Description

pmNoMangle

Utilise chaque nom de membre comme indiqué.

pmCharSetMask

Réservé.

pmCharSetNotSpec

Réservé.

pmCharSetAnsi

Marshale les chaînes sous forme de chaînes de caractères à plusieurs octets.

pmCharSetUnicode

Marshale les chaînes sous forme de caractères Unicode à 2 octets.

pmCharSetAuto

Marshale automatiquement les chaînes en les adaptant au système d'exploitation cible. La valeur par défaut est Unicode sur Windows NT, Windows 2000, Windows XP et la famille Windows Server 2003. La valeur par défaut est ANSI sur Windows 98 et Windows ME.

pmBestFitUseAssem

Réservé.

pmBestFitEnabled

Effectue un mappage ajusté des caractères Unicode qui ne disposent pas d'une correspondance exacte dans le jeu de caractères ANSI.

pmBestFitDisabled

N'effectue pas de mappage ajusté des caractères Unicode. Dans ce cas, tous les caractères non mappables sont remplacés par un « ? ».

pmBestFitMask

Réservé.

pmThrowOnUnmappableCharUseAssem

Réservé.

pmThrowOnUnmappableCharEnabled

Lève une exception lorsque le marshaleur d'interopérabilité rencontre un caractère non mappable.

pmThrowOnUnmappableCharDisabled

Ne lève pas d'exception lorsque le marshaleur d'interopérabilité rencontre un caractère non mappable.

pmThrowOnUnmappableCharMask

Réservé.

pmSupportsLastError

Permet à l'appelé d'appeler la fonction SetLastError Win32 avant de retourner une valeur à partir de la méthode avec attributs.

pmCallConvMask

Réservé.

pmCallConvWinapi

Utilise la convention d'appel de plateforme par défaut. Par exemple, la valeur par défaut est StdCall sur Windows et Cdecl sur Windows CE .NET.

pmCallConvCdecl

Utilise la convention d'appel Cdecl. Dans ce cas, c'est l'appelant qui nettoie la pile. Cela permet d'appeler des fonctions avec varargs (autrement dit, des fonctions qui acceptent un nombre variable de paramètres).

pmCallConvStdcall

Utilise la convention d'appel StdCall. Dans ce cas, c'est l'appelé qui nettoie la pile. Il s'agit de la convention d'appel par défaut pour les fonctions non managées avec appel de code non managé.

pmCallConvThiscall

Utilise la convention d'appel ThisCall. Dans ce cas, le premier paramètre est le pointeur this qui est stocké dans registre ECX. D'autres paramètres font l'objet d'un push sur la pile. La convention d'appel ThisCall permet d'appeler des méthodes sur des classes exportées à partir d'une DLL non managée.

pmCallConvFastcall

Réservé.

pmMaxValue

Réservé.

Configuration requise

Plateformes : consultez Configuration requise du .NET Framework.

En-tête : CorHdr.h

Versions du .NET Framework : 3.5 SP1, 3.5, 3.0 SP1, 3.0, 2.0 SP1, 2.0, 1.1, 1.0

Voir aussi

Autres ressources

Énumérations de métadonnées