如何比较VARIANTARG类型

问题描述:

我想构建一个函数来将VARIANTARG类型分配给DISPPARAMS结构,并且我有一些问题想出如何检查arg的实际类型。如何比较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); 

当我编译此,我在if语句得到两个错误:

error C2446: '==' : no conversion from 'const char *' to 'int' 
error C2040: '==' : 'int' differs in levels of indirection from 'const char [2]' 

所以我很困惑在这里:我为什么可以分配从VTS_I4一个字节值,但我可以稍后再比较一下?如果我将VTS_I4转换为BYTE,那么我可以比较它,但它有不同的值,所以if语句不会被触发。另一件事我可以做,因为VTS_I4在afxdisp.h中定义为“\ x03”是检查if(vt == 0x03),并且工作正常,但必须以某种方式错误。

另一种方式来问这个问题可能是为什么我能做到这一点:

BYTE a[] = VTS_I4; 

但不是这样的:

BYTE b = VTS_I4; //'initializing' : cannot convert from 'const char [2]' to 'BYTE' 

感谢

+2

也许你的意思是'VT_I4'?看看'VTS_I4'的定义。 'VTS_I4'用于为'InvokeHelper'构建一个invoke命令包。 – 2012-07-30 16:06:45

+0

这正是问题所在 - 我实际上已经复制了从InvokeHelper的调用中使用的代码,我认为这让我感到困惑。使用VT_I4的东西按预期工作(并且更好)。谢谢! – 2012-07-30 16:23:48

正如在评论中提到的,问题是我使用了错误的常量;我需要使用VT_I4而不是VTS_I4。