问题描述:
用VC2013编译了一个程序,在Windows 8、Windows 7(64位、32位)下都能正常运行。但在Win XP,Win2003下运行时,却报错不能运行,具体错误信息为“指定的可执行文件不是有效的 Win32 应用程序”。
用VS2012或VS2013在win7下编写的程序在XP下运行就出现“不是有效的win32应用程序
问题分析:
用eXeScope打开该exe,发现操作系统需求为“6.0”,即只能在Windows Vista或更高的操作系统下运行。
解决方法:
解决方法1:
项目-属性-配置属性-链接器->系统->子系统->控制台或windows 后面的”最低版本“是5.01
解决办法2:
1.用VC2013打开项目源代码,选中项目,然后右键菜单里点属性打开项目属性对话框;
2.在左侧树列表里选择 配置属性->常规,然后在右侧列表的“平台工具集”选中“Visual Studio 2013 – Windows XP (v120_xp)”,再点击确认。
改好后重新编译,就能正常运行了。
此时再用eXeScope打开该exe,发现操作系统需求为“5.1”,即能在Windows XP或更高的操作系统下运行。
参考微软的解释
http://msdn.microsoft.com/zh-SG/library/jj851139.aspx
解决办法3:
1.下载安装升级包http://www.microsoft.com/zh-cn/download/details.aspx?id=39305
2.可以通过如下的操作实现:
1).在“Solution Explorer”中选中项目,然后右键菜单里点属性。
2).在Property Pages里选择Configuation Properties,选择General,然后在Platform Toolset里选中Visual Studio 2012 – Windows XP (v110_xp)即可。
这种方法的具体说明可参考:
http://www.cnblogs.com/hwangbae/archive/2012/11/27/2790637.html
把MFC的动态链接库改成静态链接库:
此外,如果exe移植运行,不想在新计算机上查找和拷贝所依赖的MFC dll,可采用把MFC的动态链接库改成静态链接库。方法如下:
解决办法:
方案1.采用静态编译
使用VS2010编译的程序在windows xp中运行时,经常会出现找不到相关的DLL文件,我们可以使用静态编译的方法把这些运行依赖文件打包到*.exe中来,以减少对环境的依赖。
一般可以配置以下两项:
(1)项目 -> **属性 -> 配置属性 -> 常规 -> MFC的使用 :在静态库中使用MFC。
(2)项目 -> **属性 -> 配置属性 -> C/C++ -> 代码生成 -> 运行库 :多线程(/MT)。
方案2.
将mfc100.dll和应用程序一起打包发布,并在该包中加入安装控件的说明文件
方案3.
将程序和vcredist_x86.exe一起打包发布(或提示用户下载并安装vcredist_x86.exe)
我想选择方案1,方案2和3对于程序用户来说来需要注册,麻烦。(我就想要用方案1)