多线程下QAxObject指针为NULL的解决办法

Posted 随性者也

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了多线程下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");

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

以上是关于多线程下QAxObject指针为NULL的解决办法的主要内容,如果未能解决你的问题,请参考以下文章

在两个线程之间共享 QAxObject?

多线程下使用HttpContext.Current.Cache.Get(key) 获取缓存时抛出null错误

多线程死锁问题及解决办法

Clipboard.GetImage() Clipboard获取粘贴板内容为null的解决办法

iOS进阶之多线程

多线程API总结