CComVariant相关

转载 2013年12月03日 23:25:59

与使用BSTR相较而言,使用VARIANT算比较简单了,设置了类型信息和数据就完事,而且,从内存管理的角度来说,VARIANT的内存方式也相对接近常规化,因不了解而出问题的概率大大减少了,但是,为了避免万一的情况发生,我们总是不懈努力,这就是CComVariant出现的动机吧(个人诳语丷丷)。

  哈哈,其实CComVariant的出现应该从VARIANT的不足谈起(也就是所谓的使用VARIANT要遵从的几个规则):

  1.使用前必须初始化(使用VariantInit或设置VT_EMPTY)。
  2.必须使用VariantCopy函数进行拷贝,因为VARIANT的类型未知,深浅拷贝需要正确。
  3.销毁VARIANT必须使用VariantClear,因为销毁也涉及深销毁的问题。
  4.VARIANT可以选择性的使用一层简介层(最多一层),当然可以使用VariantCopyInd来消除间接性。
  5.可以使用VariantChangeType来进行类型转换。

 

  为了简化以上各个操作,ATL定制了CComVariant类,该类有如下功能(我在代码里使用了注释描述):

view plaincopy to clipboardprint?
//A.构造函数,CComVariant提供了23个构造函数,未列全   
//1.默认构造为VT_EMPTY   
CComVariant cvar1;   
//2.使用BYTE(VT_UI1)构造   
BYTE    b2  = 5;   
CComVariant cvar2(b2);   
//3.使用short构造   
CComVariant cvar3(short(5));   
//4.使用long构造   
CComVariant cvar4(long(50));   
//5.使用float构造   
CComVariant cvar5(51.25f);   
//6.使用bool构造   
CComVariant cvar6(true);   
//7.IDispatch   
IDispatch*  disp7   = NULL;   
CComVariant cvar7(disp7);   
//8.IUnknown   
IUnknown*   unkn8   = NULL;   
CComVariant cvar8(unkn8);   
//9.VARIANT   
VARIANT var9;   
var9.vt = VT_I4;   
var9.intVal = 100;   
CComVariant cvar9(var9);   
//10.const CComVariant   
CComVariant cvar10(cvar9);   
//11.CComBSTR   
CComBSTR    bstr11("hello World");   
CComVariant cvar11(bstr11);   
//12.LPCOLESTR   
CComVariant cvar12(OLESTR("hello world"));   
//13.LPCSTR   
CComVariant cvar13("hello world");   
  
//B.赋值,CComVariant定义了33个赋值操作,其中一大部分和构造函数类型对应。   
  
//C.操作,这里的这些操作都注意要进行VT_EMPTY初始化,否则可能出问题   
//1.释放   
cvar12.Clear();   
//2.拷贝,生成新的VARIANT,两者生命周期无关   
VARIANT var2;   
var2.vt = VT_EMPTY;   
cvar11.Copy(&var2);     //从var2拷贝入cvar11       
//3.Detach   
VARIANT var3;   
var3.vt = VT_EMPTY;   
cvar13.Detach(&var3);       //CComVariant本身交出生命周期控制,自己变成VT_EMPTY   
//4.Attach   
cvar13.Attach(&var3);       //VARIANT把生命周期控制交给CComVariant,VARIANT变成VT_EMPTY   
//5.类型转换   
VARTYPE vtype5;   
vtype5  = VT_INT;   
cvar2.ChangeType(vtype5);   //把cvar2向vtype类型转换   
  
//D.CComVariant的比较,CComVariant的比较分两步,首先要比较vt(类型),然后使用VarCmp进行数据比较   
  
//E.CComVariant的永久性   
IStream*    iStrm   = NULL;   
cvar13.WriteToStream(iStrm);    //写入流   
cvar13.ReadFromStream(iStrm);   //从流中读出   
ULONG   len13   = cvar13.GetSize(); //获得CComVariant在流中的预估大小,对于简单类型,是正确的预估 

 //A.构造函数,CComVariant提供了23个构造函数,未列全
 //1.默认构造为VT_EMPTY
 CComVariant cvar1;
 //2.使用BYTE(VT_UI1)构造
 BYTE b2 = 5;
 CComVariant cvar2(b2);
 //3.使用short构造
 CComVariant cvar3(short(5));
 //4.使用long构造
 CComVariant cvar4(long(50));
 //5.使用float构造
 CComVariant cvar5(51.25f);
 //6.使用bool构造
 CComVariant cvar6(true);
 //7.IDispatch
 IDispatch* disp7 = NULL;
 CComVariant cvar7(disp7);
 //8.IUnknown
 IUnknown* unkn8 = NULL;
 CComVariant cvar8(unkn8);
 //9.VARIANT
 VARIANT var9;
 var9.vt = VT_I4;
 var9.intVal = 100;
 CComVariant cvar9(var9);
 //10.const CComVariant
 CComVariant cvar10(cvar9);
 //11.CComBSTR
 CComBSTR bstr11("hello World");
 CComVariant cvar11(bstr11);
 //12.LPCOLESTR
 CComVariant cvar12(OLESTR("hello world"));
 //13.LPCSTR
 CComVariant cvar13("hello world");

 //B.赋值,CComVariant定义了33个赋值操作,其中一大部分和构造函数类型对应。

 //C.操作,这里的这些操作都注意要进行VT_EMPTY初始化,否则可能出问题
 //1.释放
 cvar12.Clear();
 //2.拷贝,生成新的VARIANT,两者生命周期无关
 VARIANT var2;
 var2.vt = VT_EMPTY;
 cvar11.Copy(&var2);  //从var2拷贝入cvar11 
 //3.Detach
 VARIANT var3;
 var3.vt = VT_EMPTY;
 cvar13.Detach(&var3);  //CComVariant本身交出生命周期控制,自己变成VT_EMPTY
 //4.Attach
 cvar13.Attach(&var3);  //VARIANT把生命周期控制交给CComVariant,VARIANT变成VT_EMPTY
 //5.类型转换
 VARTYPE vtype5;
 vtype5 = VT_INT;
 cvar2.ChangeType(vtype5); //把cvar2向vtype类型转换

 //D.CComVariant的比较,CComVariant的比较分两步,首先要比较vt(类型),然后使用VarCmp进行数据比较

 //E.CComVariant的永久性
 IStream* iStrm = NULL;
 cvar13.WriteToStream(iStrm); //写入流
 cvar13.ReadFromStream(iStrm); //从流中读出
 ULONG len13 = cvar13.GetSize(); //获得CComVariant在流中的预估大小,对于简单类型,是正确的预估

本文来自CSDN博客,转载请标明出处:http://blog.csdn.net/win2ks/archive/2008/06/09/2528471.aspx

CString 与 CComVariant 转换

1. CString 转成 CComVariantCComVariant  oComVarResult;CString strResult;oComVarResult.ChangeType( VT_...
  • primer_programer
  • primer_programer
  • 2007年12月26日 15:13
  • 3133

从Java到C++——从union到VARIANT与CComVariant的深层剖析

我第一次用VARIANT和CComVariant的时候完全不明白它是怎么回事,为它什么数据类型都可以存放,什么数据都可以被可以初始化?里面到底是怎么实现的?感觉又神奇又迷惑!我们在上一节中讲了unio...
  • luoweifu
  • luoweifu
  • 2014年06月29日 17:57
  • 2555

VARIANT 与 CComVariant 的使用

                           VARIANT 与 CComVariant 的使用   VARIANT是COM中,为了传递未知的数据类型,或者为了传递可变的数据类型,而引入的一种...
  • tangaowen
  • tangaowen
  • 2011年06月18日 12:22
  • 16858

CComVariant

 与使用BSTR相较而言,使用VARIANT算比较简单了,设置了类型信息和数据就完事,而且,从内存管理的角度来说,VARIANT的内存方式也相对接近常规化,因不了解而出问题的概率大大减少了,但是,为了...
  • liuyong8326
  • liuyong8326
  • 2009年10月27日 17:15
  • 305

CComVariant

与使用BSTR相较而言,使用VARIANT算比较简单了,设置了类型信息和数据就完事,而且,从内存管理的角度来说,VARIANT的内存方式也相对接近常规化,因不了解而出问题的概率大大减少了,但是,为了避...
  • ljz888666555
  • ljz888666555
  • 2009年08月09日 23:01
  • 515

CComVariant类

CComVariant类封装了VARIANT类型,主要的操作方法有: HRESULT Attach(VARIANT *pSrc); //清除当前对象的VARAINT成员变量,然后将pSrc赋值到该对...
  • u012612318
  • u012612318
  • 2014年03月31日 23:05
  • 464

CComVariant相关[转帖,收藏用]

 与使用BSTR相较而言,使用VARIANT算比较简单了,设置了类型信息和数据就完事,而且,从内存管理的角度来说,VARIANT的内存方式也相对接近常规化,因不了解而出问题的概率大大减少了,但是,为了...
  • china_chentao
  • china_chentao
  • 2009年04月09日 15:28
  • 876

Delphi6与VC写的COM组件如何传递BYTE*类型数据

Delphi6如何调用COM组件实现连接点的问题参照上一篇文章 今天刚刚又有了点收获赶紧写下来 Delphi6中通过SafeArray来与VC写的COM组件进行通讯。 vc端:连接点_IDispCon...
  • Pipi0714
  • Pipi0714
  • 2008年09月10日 15:43
  • 2658

正确使用CComSafeArray CComVariant CComBstr

正确的使用CComSafeArray,CComVariant和CComBSTR 如果你用C++来编写COM,那么你将必不可少的使用这三个类型。使用这三种wrapperclass毫无疑问会简化我...
  • ljz888666555
  • ljz888666555
  • 2009年08月09日 23:03
  • 807

error C2065: 'CComVariant' : undeclared identifier

当出现错误:error C2065: CComVariant : undeclared identifier时包含头文件:#include    即可 更多技术文章请参看施昌权的个人网站: http:...
  • scq2099yt
  • scq2099yt
  • 2008年03月03日 10:13
  • 1394
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:CComVariant相关
举报原因:
原因补充:

(最多只允许输入30个字)