zoukankan      html  css  js  c++  java
  • 关于_variant_t的赋值问题

    今天朋友遇到了_variant_t类型的赋值问题、整整帮他调试了1个多小时啊。。。

    这方面的问题网上也没什么好答案、自己琢磨了一个小时总算明白了

    _variant_t vtData;

    char *ptData = NULL;

    //赋值过程先略过、这方面资料好找的

    //ptData 赋上vtData大小的空间

    //ptData = new char[lDataSize+1];

    //也可以malloc这些就不说了

    ...

    //vtData用编译器的watch可以看到是数组.

    //一开始想都没想直接memcpy(ptData,&vtData,lDataSize);

    //然后发现赋值没成功

    //纠结了一个多小时后用以下方式成功

    memcpy(ptData,data.parray[0].pvData,lDataSize);

    //第二个参数是不是感觉很复杂呢?

    //_variant_t 获取到比较大的类型时、会保存到内部的SafeArray属性里去

    //然后_variant_t.parray[0] 他内部就是SafeArray变量

    //网上查了下SafeArray貌似是标准容器之类的东东。。。

    //这种东东虽然是数组他都会提供返回头指针的方式、

    //果然找到了pvData这个东东、PVOID类型、空的void类型指针嘛。。。

    //data.parray[0].pvData     SafeArray数据的首地址,类型为(void *)

    文章出处:http://www.cnblogs.com/yin52133/ 本文可自行转载,但转载时记得给出原文链接
  • 相关阅读:
    从hadoop框架与MapReduce模式中谈海量数据处理
    Hadoop
    Clone Graph
    Gas Station
    ZigZag Conversion
    String to Integer (atoi)
    Palindrome Number
    Container With Most Water
    Longest Common Prefix
    求和问题总结(leetcode 2Sum, 3Sum, 4Sum, K Sum)
  • 原文地址:https://www.cnblogs.com/yin52133/p/2556177.html
Copyright © 2011-2022 走看看