Qt SDK的x64与x86版本以及与VS的配合

本文记录了一个使用Qt 64位版本动态加载SDK DLL失败的问题,最终发现是由于目标平台不一致导致,通过调整目标平台为x86解决了该问题。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

今天遇到一个奇怪的问题,我用Qt的64位版本,动态加载一个SDK的dll,无论如何都是加载失败,QLibrary也没什么有价值的信息。

实在没辙,就用VS2013写了个小程序,用LoadLibrary来加载,嘿,碰见了RC1106错误,挡了我1个小时,最后看这里(http://blog.youkuaiyun.com/zhongchengli/article/details/6152492)解决掉了这个错误。然后,调用DLL居然成了。

于是我把Qt Creator里的项目导入到VS 2013中,心想可能会好呢,死马当作活马医吧,结果还是不好。

一怒之下,把QLibrary替换为LoadLibrary何GetProcAddress,结果还是不好。

于是我整个人都不好了。苦苦思索中,后来忽然想到目标平台,于是就去看我的小demo,发现时x86的。而我的Qt SDK和项目,是x64的。再看我用的SDK,也是x86的。

尼玛,问题找到了!重新到qt.io下载去,看下图:

qt sdk版本

看到了没,我标注的部分,带64的那个安装包,安装出来的Qt环境,库都是x64的,你用它建立的项目,默认生成的目标文件也是x64的。如果你去混合使用其他x86的SDK,就会遇到和我类似的问题。

我安装了32位的Qt SDK,结果我计算机上Qt版本太多,把VS 2013给搞乱了……编译的应用跑都跑不起来……一顿乱调整环境,把VS 2013里项目属性页中调试分类里的环境这一项的值设置了固定的Qt路径,终于可以运行了……

一个小问题来来回回折磨了将近3个小时,真是想不到……开发真是充满惊喜,你想不到你会在哪个坑里耽搁半天,耽搁多了,进度会大大偏离预期,而我们在做计划时往往看不到这些行进过程中的小障碍,所以,怎么评估都是乐观的,所以我是乐观的程序员

评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

foruok

你可以选择打赏

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值