"0xc000007b——应用程序无法正常启动"解决办法

问题

vs2013 写的一个64位的exe程序(Qt+OSG项目),debug后带着来自系统目录C:\Windows\SysWOW64\msvcr120d.dll 到一个没有runtime的win10环境去运行,没有用到MFC,所以带着这个msvcr120d.dll就足够了

但是拷贝过去后一运行就出现如下对话框:

 

 

首先怀疑msvcr120d.dll还不够,于是也拷贝了msvcp120d.dll和vccorlib120d.dll,问题依旧

其次,搜索了网络上其他人碰到的错误,做了:

失败操作案例(一下操作真心不建议去考虑)

一、缺乏dx9,于是用dxdiag命令打开看,发现系统是有dx11的,根据向下兼容,不可能缺乏dx9

为了验证,我特地重装了dx8到本机,问题依旧,所以说dx9缺乏的都是比较坑爹的,因为目前的window都是默认支持dx,更不用说dx9这么老的东西了

二、缺乏vc环境,这个我已经做了,没有缺乏

三、缺乏OSG环境,这个已经做了(包括osgearth系统环境变量设置、工程属性添加包含目录 库目录 输入附加依赖项等),没有缺乏

 

最后查到的原因所在

  1. SysWOW64目录下的dll并非确保是64位的,实际上我从这里拷贝出来的msvcr120.dll是32位的(难以想象)                        

    那么到哪里去找真正的64位的dll呢?在这里 vs2013安装目录\VC\redist\x64,这里有正统的dll                                            此外,原则上x86的也应该从该处的x86目录拷贝,毕竟这是才是面向分发的。                                                                      更换msvcr120.dll后

  2. OSG版本不匹配,新设备OSG是64位的,之前项目是32位的                                                                                                   解决办法:更换项目属性设置

 

总结

1、出现0xc000007b——应用程序无法正常启动

根本原因是缺乏所需要的DLL,提供了错误版本的dll相当于没有DLL,提示完全一样

2、网上有人说缺乏dx运行环境,如果属实,也是因为缺乏dx相关的dll

所以根本原因,在低一点

3、与程序是32还是64位没有直接关系,但是与你的程序对应不上的dll版本,往往很难发现问题,要引起注意

4、网上的资料,太粗糙了,流于表面,大家要有分辨能力。

5、发布的时候,需要vc或mfc环境,到你的开发工具的目录的redist目录去找就可以,取系统目录找就不对了

所以,以后碰到这个错误,就不需要茫然了,肯定是缺乏dll或者dll版本不对

你可能感兴趣的:(Bug)