CComVariant

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

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

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

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

//A.构造函数,CComVariant提供了23个构造函数,未列全      

  1. //1.默认构造为VT_EMPTY      
  2. CComVariant cvar1;      
  3. //2.使用BYTE(VT_UI1)构造      
  4. BYTE     b2  = 5;      
  5. CComVariant cvar2(b2);      
  6. //3.使用short构造      
  7. CComVariant cvar3( short (5));      
  8. //4.使用long构造      
  9. CComVariant cvar4( long (50));      
  10. //5.使用float构造      
  11. CComVariant cvar5(51.25f);      
  12. //6.使用bool构造      
  13. CComVariant cvar6( true );      
  14. //7.IDispatch      
  15. IDispatch*  disp7   = NULL;      
  16. CComVariant cvar7(disp7);      
  17. //8.IUnknown      
  18. IUnknown*   unkn8   = NULL;      
  19. CComVariant cvar8(unkn8);      
  20. //9.VARIANT      
  21. VARIANT var9;      
  22. var9.vt = VT_I4;      
  23. var9.intVal = 100;      
  24. CComVariant cvar9(var9);      
  25. //10.const CComVariant      
  26. CComVariant cvar10(cvar9);      
  27. //11.CComBSTR      
  28. CComBSTR    bstr11( "hello World" );      
  29. CComVariant cvar11(bstr11);      
  30. //12.LPCOLESTR      
  31. CComVariant cvar12(OLESTR( "hello world" ));      
  32. //13.LPCSTR&n

你可能感兴趣的:(UI,null,float,byte)