zoukankan      html  css  js  c++  java
  • 多线程下QAxObject指针为NULL的解决办法

    项目中需要对Excel进行操作,把数据中的数据写入到Excel文件中。在数据量大的情况下,操作Excel是一件费时的操作。

    但是执行到下列代码时就会出现空指针的情况:

    1 QAxObject *excel = new QAxObject("Excel.Application");
    2 excel->setProperty("Visible", false);
    3 
    4 QAxObject *workbooks = excel->querySubObject("WorkBooks");

    第四行返回的workbooks指针是一个空指针,无法进行向下的Excel操作。这是因为QAxObject对象是默认在单线程下使用,

    解决这个问题需要一个初始化函数,指定在多线程下可以使用QAxObject 指针。

    1 #include <ObjBase.h>
    2 
    3 CoInitializeEx(NULL, COINIT_MULTITHREADED);
    4 QAxObject *excel = new QAxObject("Excel.Application");
    5 excel->setProperty("Visible", false);
    6 
    7 QAxObject *workbooks = excel->querySubObject("WorkBooks");

    这样就可以解决上面的空指针问题。

  • 相关阅读:
    02-cocoapods的安装和使用
    01-唐巧之cocoapods
    class0513(html)
    程序集
    c#面向对象
    html
    dom
    Javascript
    Jquery
    ado.net
  • 原文地址:https://www.cnblogs.com/zhugaopeng/p/7105555.html
Copyright © 2011-2022 走看看