J'essaye de construire une fonction pour assigner des types VARIANTARG à une structure DISPPARAMS, et j'ai quelques problèmes pour savoir comment vérifier le type réel de l'argument.Comment comparer les types VARIANTARG
myFunc(int count, const BYTE* types, ...)
{
DISPPARAMS dParams;
//Initialization stuff goes here
for(int x = 0;x < count;x++)
{
BYTE vt = types[0];
dParams.rgvarg[x].vt = vt;
if(vt == VTS_I4)
{
dParams.rgvarg[x].lVal = ...;
}
}
}
BYTE params[] = {VTS_I4};
myFunc(1, params, 123);
Quand je compile ce, je reçois deux erreurs à l'instruction if:
error C2446: '==' : no conversion from 'const char *' to 'int'
error C2040: '==' : 'int' differs in levels of indirection from 'const char [2]'
Je suis donc ici assez confus: pourquoi puis-je attribuer une valeur BYTE du VTS_I4, mais je peux Ne le comparez pas plus tard? Si je jette VTS_I4 à un BYTE alors je peux le comparer, mais il a une valeur différente donc l'instruction if n'est pas déclenchée. L'autre chose que je peux faire depuis que VTS_I4 est défini dans afxdisp.h comme "\ x03" est de vérifier si (vt == 0x03), et cela fonctionne bien, mais doit être erroné en quelque sorte.
Une autre façon de poser cette question pourrait être la raison pour laquelle je peux le faire:
BYTE a[] = VTS_I4;
mais pas:
BYTE b = VTS_I4; //'initializing' : cannot convert from 'const char [2]' to 'BYTE'
Merci
Peut-être que vous vouliez dire 'VT_I4'? Regardez la définition de 'VTS_I4'. 'VTS_I4' sert à construire un paquet de commande invoke pour' InvokeHelper'. –
C'était exactement le problème - j'avais effectivement copié le code que j'utilise à partir d'une invocation de InvokeHelper, et je pense que c'est ce qui m'a rendu confus. En utilisant VT_I4 les choses fonctionnent comme prévu (et beaucoup plus agréable aussi). Merci! –