Avertissement du compilateur (niveaux 1 et 3) C4793
'fonction' : la fonction est compilée comme code natif : 'raison'
Le compilateur ne peut pas compiler la function dans le code managé, bien que l'option /clr du compilateur soit spécifiée. À la place, le compilateur émet l'avertissement C4793 et un message de continuation explicatif, puis compile la function dans le code natif. Le message de continuation contient le texte de reason qui explique pourquoi la function ne peut pas être compilée dans MSIL.
Il s'agit d'un avertissement de niveau 1 émis lorsque vous spécifiez l'option /clr:puredu compilateur.
Le tableau suivant répertorie tous les messages de continuation potentiels.
Message de raison |
Remarques |
---|---|
Les types de données alignés ne sont pas pris en charge dans le code managé |
Le CLR doit être en mesure d'allouer autant de données que nécessaire, ce qui peut ne pas être possible si les données sont alignées avec les déclarations telles que __m128 ou aligner. |
Les fonctions utilisant "__ImageBase" ne sont pas prises en charge dans le code managé |
__ImageBase est un symbole d'éditeur de liens spécial utilisé en général uniquement par le code natif de bas niveau pour charger une DLL. |
Les varargs ne sont pas prises en charge par l'option '/clr' du compilateur |
Les fonctions natives ne peuvent pas appeler les fonctions managées qui ont des listes d'arguments variables (varargs) parce que les fonctions ont des spécifications de disposition en pile différentes. Toutefois, si vous spécifiez l'option /clr:pure du compilateur, les listes d'arguments variables sont prises en charge parce que l'assembly peut contenir uniquement des fonctions gérées. Pour plus d'informations, consultez Code pur et vérifiable (C++/CLI). |
Le CLR 64 bits ne prend pas en charge les données déclarées avec le modificateur __ptr32 |
Un pointeur doit être de la même taille qu'un pointeur natif sur la plateforme actuelle. Pour plus d'informations, consultez __ptr32, __ptr64. |
Le CLR 32 bits ne prend pas en charge les données déclarées avec le modificateur __ptr64 |
Un pointeur doit être de la même taille qu'un pointeur natif sur la plateforme actuelle. Pour plus d'informations, consultez __ptr32, __ptr64. |
Un ou plusieurs intrinsèques ne sont pas pris en charge dans le code managé |
Le nom de l'intrinsèque n'est pas disponible au moment où le message est émis. Toutefois, un intrinsèque qui déclenche ce message représente en général une instruction machine de bas niveau. |
L'assembly natif inline ("__asm") n'est pas pris en charge dans le code managé |
Le code assembleur inline peut contenir du code natif arbitraire qui ne peut pas être géré. |
Un thunk de fonction virtuelle de non-__clrcall doit être compilé comme natif |
Un thunk de fonction virtuelle non-__clrcall doit utiliser une adresse non managée. |
Une fonction utilisant '_setjmp' doit être compilée comme native |
Le CLR doit être en mesure de contrôler l'exécution du programme. Toutefois, la fonction setjmp contourne l'exécution normale du programme en enregistrant et restaurant des informations de bas niveau telles que les registres et l'état d'exécution. |
Exemple
L'exemple suivant génère l'erreur C4793.
// C4793.cpp
// compile with: /c /clr /W3
// processor: x86
int asmfunc(void) { // C4793, compiled as unmanaged, native code
__asm {
mov eax, 0
}
}
L'exemple suivant génère l'erreur C4793.
// C4793_b.cpp
// compile with: /c /clr /W3
#include <setjmp.h>
jmp_buf test_buf;
void f() {
setjmp(test_buf); // C4793 warning
}