[转]正确解决:坑爹的0xc000007b——应用程序无法正常启动

本文转自:http://blog.sina.com.cn/s/blog_654116410102x9hr.html

注:本文对0xc000007b的问题本质进行了说明,可以说对网上杂七杂八的声音做了一个统一。

问题情景:

vs2013 写的一个64位的exe程序,release后带着来自系统目录C:\Windows\SysWOW64\msvcr120.dll

到一个没有runtime的win7环境去运行,没有用到MFC,所以带着这个msvcr120.dll就足够了,但是

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

首先怀疑msvcr120.dll还不够,于是也拷贝了msvcp120.dll和vccorlib120.dll,问题依旧

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

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

为了验证,我特地重装了dx8到本机,问题依旧,所以说dx9缺乏的都是比较坑爹的,因为目前的

window都是默认支持dx,更不用说dx9这么老的东西了

2.说缺乏vc环境,这个我已经做了,没有缺乏

最后查到的原因所在,出乎你们的想象:SysWOW64目录下的dll并非确保是64位的,实际上我从这里

拷贝出来的msvcr120.dll是32位的。那么到哪里去找真正的64位的dll呢?在这里 vs2013安装目录\VC\redist\x64,

这里有正统的dll。此外,原则上x86的也应该从该处的x86目录拷贝,毕竟这是才是面向分发的。

更换msvcr120.dll后,问题排除。

总结:

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

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

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

所以根本原因,在低一点

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

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

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

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

另一种解决方案:把两个64位的dll拷贝到工程目录下

 

posted @ 2018-11-06 19:09  研究僧小陈  阅读(3498)  评论(0编辑  收藏  举报