[Qt学习笔记]Qt使用MFC编译生成dll库在无编程环境电脑出现无法加载dll的问题

目录

  • [1、 问题介绍](#1、 问题介绍)
  • [2、 问题分析](#2、 问题分析)
  • [3、 问题总结和思考](#3、 问题总结和思考)

1、 问题介绍

在项目实践中,使用Qt调用了一个vs创建的dll库,在本机上编译和release后的exe可以加载对应的dll文件,将exe拷贝到有vs编程环境的电脑上也可以加载对应的dll文件,但在无编程环境的电脑上执行exe就会出现无法加载dll的bug。

2、 问题分析

刚碰到这个问题的时候,感觉可能是dll的依赖项的确实,或者是vc运行库的缺失,如是在新电脑上安装了VC运行库,并使用dependency walker查看了该dll的依赖项并进行补全,发现问题依然存在,接下来考虑的是dll自生生成的环境依赖问题,如是找到了该dll项目的生成环境,将dll生成的运行库设置为"多线程(/MT)",再重新生成dll就解决新电脑无法加载dll的bug。

3、 问题总结和思考

这里重新学习一下MFC这种生成dll设定运行库的原理。

编译选项 包含 静态链接的lib 说明
/MD _MT、_DLL MSVCRT.lib 多线程、Release、DLL版本的运行时库
/MDd _DEBUG、_MT、_DLL MSVCRTD.lib 多线程、Debug、DLL版本的运行时库
/MT _MT LIBCMT.lib 多线程、Release版本的运行时库
/MTd _DEBUG、_MT LIBCMTD.lib 多线程、Debug版本的运行时库
这里就要注意/MD和/MT的区别了

/MD表示运行时库不集成,一般生成的文件小,如果系统有依赖库可有效减少文件大小。

/MT表示运行时库集成,生成文件大,自带了该dll的依赖库

/MT和/MD选择的要领

  • 1 以下情况选择/MT
    1)有些系统可能没有程序所需版本的运行时库,程序必须把运行时库静态链接上;
    2)减少模块对外界的依赖;
  • 2 以下情况选择/MD
    1)程序就不需要静态链接运行时库,可以减小软件的大小;
    2)所有的模块都采用/MD,使用的是同一个堆,不存在A堆申请,B堆释放的问题;
    3)用户机器可能缺少我们编译时使用的动态运行时库。(补充:如果我们软件有多个DLL,采用/MT体积增加太多,则可以考虑/MD + 自带系统运行时库)
  • 3 注意:如果软件有多个模块dll,必须选择相同的运行时库;
相关推荐
机器视觉知识推荐、就业指导2 小时前
面试问题详解五:Qt 信号与槽的动态管理
开发语言·qt
四维碎片8 小时前
【Qt】线程池与全局信号实现异步协作
开发语言·qt·ui·visual studio
feiyangqingyun13 小时前
纯Qt结合ffmpeg实现本地摄像头采集/桌面采集/应用程序窗口采集/指定采集帧率和分辨率等
qt·ffmpeg·qt桌面采集·qt摄像头采集·qt程序窗口采集
王廷胡_白嫖帝18 小时前
Qt个人通讯录项目开发教程 - 从零开始构建联系人管理系统
开发语言·qt
戏言zare18 小时前
Qt设置软件使用期限【新版防修改系统时间】
qt
大橘19 小时前
【qml-5】qml与c++交互(类型单例)
qt·qml
lxmyzzs1 天前
pyqt5无法显示opencv绘制文本和掩码信息
python·qt·opencv
大橘1 天前
【qml-4】qml与c++交互(类型多例)
qt·qml
Forward♞2 天前
Qt——文件操作
开发语言·c++·qt
王廷胡_白嫖帝2 天前
Qt猜数字游戏项目开发教程 - 从零开始构建趣味小游戏
开发语言·qt·游戏