一、问题详情
使用 visual studio
完成 C++
的代码编写后,编译成可执行程序,会遇到编译后,在其他设备上报缺乏dll
错误导致程序无法运行的情况,下面先介绍解决方法,再对其原理进行简单描述。
二、解决方案
项目 -> 属性 -> 配置属性 -> C/C++ -> 代码生成 -> 运行库 -> 多线程 (/MT)
截图如下:
三、原理
1. 基本概念(MT、MTd、MD、MDd)
下面我们一起看一下MSDN上对编译选项MT
、MTd
、MD
、MDd
的介绍。
MT:mutithread
,多线程库,编译器会从运行时库里面选择多线程静态连接库来解释程序中的代码,即链接LIBCMT.lib
库。
MTd:mutithread
+debug
,多线程调试版,链接LIBMITD.lib
库。
MD:MT
+DLL
,多线程动态库,链接MSVCRT.lib
库,这是个导入库,对应动态库为MSVCRT.dll
。
MDd: MT
+DLL
+debug
,多线程动态调试库,链接MSVCRTD.lib
库,对应动态库为MSVCRTD.dll
。
我们开发多线程程序时,需要选择MT
、MTd
、MD
、MDd
其中的一个。
2. 静态库/动态库
对于MT/MTd
,由于链接运行时库是LIBCMT.lib/LIBCMTD.lib
,这两个库是静态库,所以此种方式编译的程序,移到另一台机器上面也可以正常运行。
但是对于MD/MDd
,链接的是动态库,所以如果另一台机器上没有MSVCRT.dll/MSVCRTD.dll
时,就提示缺少动态库这样的错误。
关于Linux上进行2种编译方式的例子可参考:windows 编译 libcurl 7.65.0
3. 注意事项
那以MT/MTd方式编译,程序对所有的库都是静态链接吗?显然不是。
对用户自己写的库或其他第三方库,其链接方式取决于代码(显式链接动态库Loadlibrary
)或所提供的lib
文件(为导入库还是静态库),移动程序到别的机器上时,还是要带上所需要的动态库的。
4. 别人的程序无法运行
对于在其他设备上程序无法运行的解决方法,还有以下2种方式:
(1) 在运行程序的计算机上安装vc20xx
运行库(取决于程序的vs版本
说明:这种方法需要用户自己去安装,一般适用于大型程序,小程序不建议使用。
(2) 在应用程序同目录上附带MSVCRxx.DLL
文件(取决于程序的vs版本
说明:这种方法适用于一些小项目,无需用户另外安装程序。