遇到这个问题,一定是缺少了CRT、MFC、ATL的DLL,不同版本的VS是不一样的。系统自带这些库的Release版,如果没有自带,打补丁就有了;系统不自带这些库的Debug版,所以Debug版的程序在一般电脑是不能正常运行的(不过装了对应版本的VS就可以正常运行了)。这篇博文对VS2008 部署应用程序 “应用程序配置不正确,程序无法启动”的问题有比较详细的解决方案,有兴趣的童鞋可以看一看。
如果是部署环境导致了这个错误,那么上一段提到的那篇博文足矣解决问题,如果是程序本身的错误,那么需要进一步进行排查。最近我的一个VS2005开发的项目,发布Rlease版本,部署到其他电脑的时候,有些电脑提示“应用程序无法正常启动( 0x0150002)” 如图1,有些正常。经过不断测试,发现该错误与XP、Win7和Win8系统无关,与是否安装VS2005环境有关。很明显,Release版的程序却需要Debug版的库,基本可以断定是我的程序出了问题。虽然通过安装VS2005或添加VS2005 Debug版的CRT、MFC、ATL库可以让程序运行,但这只是掩盖了问题,并没有解决问题。
图1 应用程序正常初始化 0x0150002失败
遇到这种莫名其妙的问题,直接Google报错提示是最佳选择,但是在Google到的方法都不起作用的时候,需要通过日志去分析到底哪里出问题,方法如下:
1、右键“计算机”,打开“管理”,选择“系统工具”—“事件查看器”—“Windows日志”—“应用程序”,如图2所示。右边可以看到错误信息,第一条就是我想要找的错误信息;
图2 查看应用程序出错日志
2、双击该错误信息,弹出图3日志信息。该信息比“应用程序无法正常启动( 0x0150002)” 有用多了,疑点有两个,一个是少了CRT库,另一个是ACE.dll有问题。毫无疑问,既然是发布Release版本,还要Debug版本的库,是这个ACE.dll出了问题;
图3 应用程序出错日志
回到VS2005查看程序,果然,之前太大意了,ACE.dll竟然是Debug版,难怪出问题了。重新编译Release的ACE.dll,替换原先的ACE.dll,问题解决。