VC的自动化向导的BUG (vs2005调用LabView控件类成员函数报错)

在VS2005的MFC程序中使用LabView Slider控件时遇到成员函数调用错误,原因是VC7的向导生成的封装类对VARIANT类型的处理方式与VC6不同,导致程序崩溃。解决方案是将成员函数修改为VC6风格,或者避免使用VARIANT类型。通过查阅MSDN,发现可以直接使用float类型赋值,修改SetValue函数并成功运行。
摘要由CSDN通过智能技术生成

   在vs2005的mfc程序中使用LabView的Slider控件,添加变量后,调用赋值成员函数

_variant_t var(50.99); 
m_BatterySlide1.SetValue(var);

    程序报错:

程序中断处:

			case VT_VARIANT:
				//VARIANT is always passed by ref
				*pArg = *va_arg(argList, VARIANT*);
				break;

   查看Slider类的成员函数:

void SetValue(VARIANT propVal)
{
	SetProperty(0x101, VT_VARIANT, propVal);
}

   在网上查这个问题,发现

   VC6的向导产生的封装类对VARIANT类型的属性的处理是传地址
void CAxCtrlAV::SetFoo(const VARIANT& propVal)
{
    SetProperty(0x1, VT_VARIANT, &propVal);
}

VC7的向导产生的封装类对VARIANT类型的属性的处理是传值
void CAxCtrlAV::SetFoo(VARIANT propVal)
{
    SetProperty(0x1, VT_VARIANT, propVal);
}

因为VC7的va_list/va_start的 行为改为替换栈层次而不是实际上保存参数的地址,对属性的访问最终会在COleDispatchDriver::InvokeHelperV中导致程序崩溃。解决该问题的方法是手工将VC7的类向导产生的封装类的定义和实现更改为VC6风格的,或者不使用VARIANT做为属性的类型。

   链接:http://blog.csdn.net/jiangsheng/article/details/353978

   按照此方法,修改SetVlaue成员函数为:

void SetValue(const VARIANT& propVal)
{
	SetProperty(0x101, VT_VARIANT, &propVal);
}

   再次执行程序,运行成功!

  进一步思考,这样赋值仍不够直观,为Slider控件赋值,只需传float型变量,如果SetValue函数能直接接收float类型参数,则使用起来更加直观方便。

  观察这样的函数,接收参数类型与SetProperty函数的第二个参数VT_VARIANT&

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值