VS2013编译的exe独立运行在XP中方案

转载知乎

现在,我们深入探讨一下:
《如何使用VS 2013发布一个可以在Windows XP中独立运行的可执行文件》。

这个问题是比较常见且容易造成初学者困惑的,作为曾经撞了无数次南墙的初级代码狗终于看到了自己能够回答的问题,那么就让我来简单阐述一下造成这个问题的简单原理极其简单解决方法,如有错误纰漏敬请指正。

/*我们讨论的是非托管的C++程序。*/

为了方便说明,我们新建一个简单的控制台应用程序项目,直接如图:

非常简单,一个使用了C++标准库的控制台应用程序,在装有开发环境的本机顺利执行出如下效果:

真是一个旷世奇作,我们迫不及待地就此发给XP老哥炫耀,万万没想到:

装逼不成反被XP老哥奚落:“负分滚粗!”

这里我们遇到了题主遇到的问题之一,确实叫人纳闷,不过随便搜索一下就会有解决方法:

是的,在项目配置属性中,将平台工具集选择为"Visual Studio 2013 - Windows XP (v120_xp)",即可解决“无效的 Win32 应用程序”问题

但是我们还要知其所以然,为什么?
项目默认的Visual Studio 2013(v120) 与 Visual Studio 2013 - Windows XP(v120_xp) 生成出来的可执行文件有何区别,以至于前者在XP上执行会出现那样的错误?

最直觉的方法自然是比较一下两版执行文件的区别,我们选用PE (Portable Executable:32位或64位Windows操作系统使用的可执行程序或者动态链接库的文件格式)工具 Stud_PE 进行PE文件头结构比较,很容易看到区别:

看到打红叉的地方,就是两个文件不同之处,其他地方几乎没有区别。
关于PE文件结构是另外一个话题,我们暂不深入讨论。
单就这两处我们顾名思义一下就很容易明白:
MajorOSVersion ,(目标)操作系统主版本号 ,选择默认平台工具集的文件的值是6,后者是5。
MinorOSVersion ,(目标)操作系统次版本号,前者是0,后者是1。
MajorSubsystemVersion,(目标)Win32子系统主版本号,前者是6,后者是5。
MinorSubsystemVersion,(目标)Win32子系统次版本号,前者是0,后者是1。

总结一下:一个是6.0 ,一个是5.1 。
很明显5.1不就是XP的版本号么,6.0就是Vista呗?
我们是否可以认为,项目默认选择的“平台工具集”生成的可执行文件是不能在6.0以下版本的Windows运行的?

试验结果是:当我把6.0手动修改成5.1之后,这个文件立刻可以正常在XP里运行了,事实上Major/MinorOSVersion的值似乎没有起到什么作用,仅仅修改XxxxxSubsystemVersion的值就可以保证程序顺利执行起来了。反之亦然。同时还发现:在XP中,改为5.1可以,5.2及更高就不行。

对于这个问题的认识虽然仍流于表面,但由于知识有限,我们就不再深究PE结构中的这几个值的深层次含义了。当然如有大牛指点一二就更好了。

现在好了!我们不但解决了XP的运行问题,还大致了解了问题的根源。那么让我们继续发布吧!

将新的、XP的、“5.1的”版本发给XP老哥:

我勒个去?你等等,我再编译一个release版本…… 试试:

擦?不是说好的“Release"吗?你等等,不就是一个dll文件吗,我这里有!我发给你……
我从自己的系统(Win 8.1 x64)C:\Wdinwos\system32 文件夹找一个MSVCP120.DLL发过去:

是啊,这不是逗呢?拿64位的dll文件去冒充32位,能行? 重新去VS目录里扒一个正确的32位msvcp120.dll 补上:

又来,这次叫做MSVCR120.dll ,不仔细看还真没认出来。继续补上:

呵呵呵呵呵,终于得以正确运行了,但是这么狼狈的炫耀怎么能让人高兴起来呢?

经过一番折腾,好歹知道了是因为缺少文件,那么下次发布程序把这些瓶瓶罐罐DDLL都带上打包不就行了吗?没错,确实是这么个道理,但总感觉很不专业的样子。

所以一个正常的解决方案就是和其他答案中所说的那样,让目标机器安装 
VisualC++Redistributable Packages forVisualStudio2013 。

这个东西的作用就是:

安装运行使用 VisualStudio2013 生成的 C++ 应用程序时所需的运行时组件。

简单观察安装后系统中多出了哪些文件:

这样一看,“运行时组件”就变得直观和具体了。
它们都是什么呢?我们先去VS的安装目录中看一下:

通过路径很容易理解,这是有关VC的redist(再发行)的东西,我们进x86看一下:


有关CRT(运行时库),MFC,MFCLOC(MFC的本地化文件)等等,我们看看CRT里面:

看到了眼熟的这两个dll了,实际上你参考前面那个XP多出文件的图片,那些dll都能在这里找到。
这就是 Visual C++ Redistributable 包括的东西,每个VS版本都不一样。VS2013对应的就是120。

那管它是VS2013还是2012还是2008,对应的发行包给装上不就完了。

没错。但是我们还要继续研究一下,至少,研究一下如何让一个可执行文件“独立”运行在XP上。

回到项目配置,如下图:

我们看到,运行库这一项,包含4种选择。
废话不多说,我们简单粗暴干脆每一种都生成一个进行比较:

四种版本,分别起了对应的名称,多线程(MT),多线程DLL(MD),多线程调试(MTd),多线程调试DLL(MDd)。
利用 Stud_PE 观察比较它们的 函数导入表 ,发现:
1. 多线程DLL (MD)和 多线程调试DLL (MDd)
两者都导入了2个MSVCxxxx.dll (黄箭头所指),但细看又不同,调试版本(MDd)导入的是MSVCP120D.dll和MSVCR120D.dll,比非调试(MD)的那个都多一个字母D。很明显这是配套给调试版的运行时库。而我们之前安装的发行包所部署的都是不带D的版本,是给Release版的程序配套使用的。
顺便一提MSVCP代表MicroSoft Visual C++(Plus) ,MSVCR则代表MicroSoft Visual C(没有+)Runtime。 一个是C++运行时库一个是C运行时库。

2.多线程(MT) 与 多线程调试(MTd)貌似一样,都没有MSVCP和MSVCR函数导入,只有Kernel32.dll。同时观察这两个文件的体积,都比MD或MDd大了很多,这正是它们不需要导入运行时库DLL函数的原因,因为它们把运行时库静态编译到自己的文件中去了。这也代表着它们运行的时候不会再依赖外部的运行时库DLL文件。

所以答案就在这里,想要你的exe独立运行在XP中:
1.将平台工具集选择为"Visual Studio 2013 - Windows XP (v120_xp)"。
2.将运行库选择为 【多线程 /MT 】或【多线程调试 /MTd】。
3.当然如果使用了MFC,同理的要设置【在静态库中使用MFC】:

时间: 2024-07-31 06:20:29

VS2013编译的exe独立运行在XP中方案的相关文章

【转】如何使用VS 2013发布一个可以在Windows XP中独立运行的可执行文件

问题描述: 用VS2013写好一个程序,在本机上运行一切正常.但是如果直接把exe文件放到另一台机器上用,则会出现: Windows XP:不是一个正常的win32程序 Window 7:缺少msvcp120.dll 能否有一种方法,把程序运行所需要的环境一并打包,使之可以在任何Windows计算机上使用? 为了方便说明,我们新建一个简单的控制台应用项目,直接如图: 非常简单,一个使用了C++标准库的控制台应用程序,在装有开发环境的本机顺序执行出如下效果: 真实一个旷世奇作,我们迫不及待地就此发

让用VS2013编写的程序在XP中顺利运行

vs2013编译好的exe文件拖到虚拟机xp中无法运行,提示错误,从网上搜索.找答案. 参考:http://blog.csdn.net/asanscape/article/details/38752655,经过如下四步操作,可以实现win7下vs2013编译的exe可以在xp下运行. 1. 项目菜单->项目属性->配置属性->常规->平台工具集,选择“VS2013WindowsXP(v120_xp)”; 2. 项目菜单->项目属性->配置属性->常规->MF

【转】VS2012编译出来的程序,在XP上运行,出现“.exe 不是有效的 win32 应用程序” “not a valid win32 application”

原文网址:http://www.cnblogs.com/Dageking/archive/2013/05/15/3079394.html VS2012编译出来的程序,在XP上运行,出现“.exe 不是有效的 win32 应用程序” “not a valid win32 application” 升级vs2010到vs2012,突然发现build出来的应用程序无法运行,提示“不是有效的 win32 应用程序” or “not a valid win32 application”. 参考CSDN论坛

VS2012编译出来的程序,在XP上运行,出现“.exe 不是有效的 win32 应用程序” “not a valid win32 application”

升级vs2010到vs2012,突然发现build出来的应用程序无法运行,提示“不是有效的 win32 应用程序” or “not a valid win32 application”. 参考CSDN论坛中的方法,找到下面这篇文章: http://blogs.msdn.com/b/vsnetsetup/archive/2012/10/16/setup-exe-is-not-a-valid-win32-application.aspx You would receive the below err

【Visual Studio】让用VS2012/VS2013编写的程序在XP中顺利运行(转)

原文转自 http://blog.csdn.net/asanscape/article/details/38752655 微软为了推销自家平台,默认配置下VS2012和VS2013编写的应用程序只能在Vista/Win7/Win8上运行.但幸好还保留了生成XP程序的设置项.XP和Win2003的用户还是大量存在的,我们程序软件的发布不能不考虑他们. 1. 项目菜单->项目属性->配置属性->常规->平台工具集,选择"VS2013WindowsXP(v120_xp)&quo

让用VS2012/VS2013编写的程序在XP中顺利运行

转自:http://blog.csdn.net/asanscape/article/details/38752655/ 微软为了推销自家平台,默认配置下VS2012和VS2013编写的应用程序只能在Vista/Win7/Win8上运行.但幸好还保留了生成XP程序的设置项.XP和Win2003的用户还是大量存在的,我们程序软件的发布不能不考虑他们. 1. 项目菜单->项目属性->配置属性->常规->平台工具集,选择“VS2013WindowsXP(v120_xp)”; 2. 项目菜单

VS2013 help viewer搜索结果显示源码以及桌面独立运行help viewer

安装好VS2013后,启动help viewer2.1在搜索栏中搜搜时结果会出现HTML源码. 要解决这个问题先来看看MINE,即Multipurpose Internet Mail Extensions(多用途互联网邮件扩展类型),它是用于电子邮件.网络文档以及Internet上其他应用程序中的文件格式规范.它设定了某种扩展名的文件用一种指定的应用程序打开的类型,当该扩展名的文件被访问时,浏览器会自动指定相应的应用程序打开.其中HTML属于MINE其中的一种格式,而在VS help viewe

vs2013编译的程序在其他机器上运行的环境设置

vs2013编译的程序在其他没有安装vs2013的机器上运行会有问题,网上有很多解决方法,如果你还没有解决,可以尝试以下方法,这是我在反复崩溃,烦躁测试后得到的解决方法. 1. 安装vs2013 运行包 vcredist_x64.exe 如果这个时候还是不能正常执行,请不要和我一样崩溃, 试试我的解决方法,对这个运行包进行修复 控制面板--程序--程序和功能 在程序列表里找到 vc++ 12.0.30501 选中,修复 这样就可以打开vs2013编译出来的程序了,我碰到的情况是这样解决的. ==

将java应用程序打包成独立运行的.exe方法

对于windows用户来说,将java应用程序打包成.exe最好不过了,现在我介绍两个方法. 1.用专业的应用程序打包工具InstallAnywhere,这个软件几乎能在所有平台上运行,当然你要下载到你需要的那个平台的啦!而且它也能打包成各个平台的安装程序(当然不是免费的).我下载的是7.1 企业版我只提供一些注册码,安装程序大家在网上找.InstallAnywhere7.1注册码使用方法参考:具体 2.用MINI的免费的工具javalunch,JavaLauncher的下载网址是:http:/