VC-"应用程序正常初始化失败"-0xc0150002

VC-"应用程序正常初始化失败"-0xc0150002

最近几天被这个问题困惑了许久。 不禁感叹微软的东东真是越做越烂了,也终于明白了时隔12年大家仍然死守VC6的原因。。 

  用VC2005/VC2008编译的程序,编译时没有任何错误,但是运行时就是提示“应用程序正常初始化失败”!! 查找了各方面资料,做了各种尝试,网上说什么的都有:有让安装vc2005 sp1补丁的;有让安装vcredist_x86.exe的; 有让把CRT库的dll直接拷贝到程序目录的; 有让清理注册表的;有让装.NetFramework新版本的;有让查manifest的; 

  结果我尝试了半天,几乎都是浪费时间。上面最后一条说的还算正确,只是作者把事情描述得太繁琐了。。现在把处理的方法说一下,省得大家再走弯路: 

  1. VC2003、VC2005、VC2008及其后续版本,对底层最基本的CRT、MFC、ATL库都进行了重构,为了避免不同版本的库引起冲突,重构后的库文件一般放在 C://windows/WinSxS 文件夹中,并用特定的文件夹/文件名称进行标识; 

  2. 与VC6不同, VC2003、VC2005、VC2008及其后续版本,引入了manifest清单的概念,即应用程序编译后会同时生成对应的.manifest文件,并将该.manifest文件作为资源编译到dll或者exe中去。.manifest文件实际上是一个XML格式的文本文件,里面记录了dll或exe中要引用的CRT、MFC、ATL库的版本和名称。VC6编译的应用程序对CRT、MFC、ATL的dll都是直接调用,而VC2003、VC2005、VC2008编译的程序都是先查询编译到资源中的manifest中的记录,然后按照记录提供的版本和名称去搜寻对应的CRT、MFC、ATL库以及随库发布的.manifest文件,搜寻的路径包括当前目录、C://windows/WinSxS 等等,如果没有找到对应的库文件,则提示“应用程序正常初始化失败”; 

  3.因此解决这个问题的办法就是:(a)用文本编辑器打开exe或dll对应的.manifest文件,查看它引用的CRT、MFC、ATL库的版本;或者,用UltraEdit直接打开exe或者dll,从资源区中找到编译进去的.manifest信息,找到它引用的CRT、MFC、ATL库的版本;或者,运行程序,当程序弹出“应用程序正常初始化失败”对话框时,在桌面上右键点击“我的电脑”-“管理”-“事件查看器”-“系统”,双击查看其中的记录,可以看到出错的原因是因为缺少了某某版本的CRT、MFC、ATL库,记录下这个版本信息;(b)记录到的库的版本信息一般类似于“Microsoft.VC90.DebugCRT”,之后到C://windows/WinSxS 或者VC200X的安装文件夹中搜索包含这个字符串的文件夹和文件,将搜索到的dll和.manifest文件都拷贝到应用程序所在的文件夹中,其中,.manifest文件必须重命名为“Microsoft.VC90.DebugCRT.manifest”(这里以Microsoft.VC90.DebugCRT为例),这样应用程序就可以正常运行了;(c)注意:库的.manifest文件和dll要一同拷贝到应用程序根目录去,因为应用程序会将编译到内部的manifest信息与外部的.manifest文件进行对比,之后才会对库的dll进行调用。如果只拷贝库的dll文件是没有用的; 

  4.如果本机编译和运行程序都ok,但是将编译好的程序拿到其它机器上确无法运行,则多半也是这个原因。另外,如果提示"应用程序配置不正确",大多也是因为上面所说的CRT、MFC、ATL库版本与应用程序不匹配导致的,可以如法炮制进行解决; 

 

*****************************************

注意

主要的原因是没有vs开发环境的运行环境CRT、MFC、ATL库版本的问题

安装相应vs版本运行库即可

方法二:


        写了一个VC6下的MFC程序,结果拷贝到另一台机子上出现了应用程序正常初始化(0xc0150002)失败的问题。然后打开事件查看器,

找到了如下信息:

找不到附属汇编 Microsoft.VC80.DebugCRT,上一个错误是 参照的汇编没有安装在系统上。

Resolve Partial Assembly 为 Microsoft.VC80.DebugCRT 失败。 参考错误消息: 参照的汇编没有安装在系统上。
Generate Activation Context 为 C:\Documents and Settings\jerry\桌面\ProConfigure\Debug\MXML1.dll 失败。 参考错误消息: 操作成功完成。



        可以判断是dll加载的时候出了点问题了,看了下它的manifest文件,其依赖库是Microsoft.VC80.DebugCRT ,这样问题就很明显了,
这个dll是在VS2005下编译的,而别人的机子上没有这个环境,我们所编译生成的应用程序由于缺少必需的Debug版本的VC运行库而发生错误。

        解决方法:到第一台机子上的vs2005的安装目录下,搜索名字中包含串Microsoft.VC80.DebugCRT的文件,共有3个dll文件 msvcm80d.dllmsvcp80d.dllmsvcr80d.dll和一个manifest文件( Microsoft.VC80.DebugCRT.manifest),拷贝到另一台机
子上的工程可执行文件目录下,问题就解决了。


方法其他:

vs2005做的c++,在本机都能运行,然后到虚拟机(.net framework2.0已经安装,还安装了vcredist)

控制台程序--正常;
MFC应用程序(使用静态库)--正常;

MFC应用程序(使用共享DLL)--报错;
窗体应用程序--报错;

错误星信息一样:“由于应用程序不正确,程序不能启动.重新安装应用程序可能会解决这个问题.”

如果是c#做的窗体应用程序的话,在这个虚拟机里是能运行的。
哪位大哥能讲讲是为什么啊?


解答:

首先以及再次感谢Avoid兄,乃素好人呐~ ^-^
终于解决问题了,把经验贴出来,方便以后有人遇到此类问题时解决

Avoid兄给出的链接里的四种方法的可行性说明以及详细运行过程:
关于“由于应用程序不正确,应用程序不能启动......”
方法一基本可行,方法二和方法三也可行,方法四估计不可行。
方法一:
在X:\Microsoft Visual Studio 8\VC\redi
st\Debug_NonRedist\x86\Microsoft.VC80.DebugCRT 下找到了下列文件:
msvcm80d.dll
msvcp80d.dll
msvcr80d.dll
Microsoft.VC80.DebugCRT.manifest //其实就是所有文件-_-!
把这几个文件拷贝到目标机器上,与运行程序同一文件夹,就可以运行那个程序了。

之所以说基本可行是因为那文章中所提到的“或者拷贝到SYSTEM32文件夹下”是不可行的,在这里我去掉了。
还有就是,未必一定得是Microsoft.VC80.DebugCRT,如果你建立的是“windows窗体应用程序”项目就用Microsoft.VC80.DebugCRT,如果你建立的是“MFC应用程序”项目那就用Microsoft.VC80.DebugMFC

其实这个方法以前看到过,不过我搞错文件夹了,一直拖到今天才弄清楚,各位注意了在和Debug_NonRedist同级的文件夹里也有个X86,不是它,别进错了!

方法二和方法三其实是联系在一起的:
方法二:
工程-》属性-》配置属性-》代码生成-》运行时库,将/MD或/MDd 改为 /MT或/MTd,这样就实现了对VC运行时库的静态链接,在运行时就不再需要VC的dll了。注:MDd和MTd是DEBUG版本的,不带小d的是RELEASE版本.

方法三:
工程-》属性-》配置属性-》常规-》MFC的使用,选择"在静态库中使用mfc"
这样生成的exe文件应该就可以在其他机器上跑了。
而这两个方法就是我在主贴里提到的“MFC应用程序(使用静态库)--正常; ”,也就是当你在建立“MFC应用程序”项目时在向导的第二步中选择了“在静态库中使用MFC”,得到的就是方法二和方法三联合起来的效果。

方法四:
在主贴里已经说明了,我虚拟机里是装了vcredist的。
vcredist是微软官方出的一个东西,关于它的说明“Microsoft Visual C++ 2005 SP1 Redistributable Package (x86) 安装在未安装 Visual C++ 2005 的计算机上运行使用 Visual C++ 开发的应用程序所需的 Visual C++ 库的运行时组件。”
但是编的程序仍然无法运行,后来我卸载了它,今天为了验证这四种方法,又重装时,竟然无法安装了!!!无论是最初的版本还是这个月15号出的SP1版!!!微软出它来到底是干什么的...-_-! 希望诸位看官能给个答案...

呵呵~终于搞完了,下面是第一次来运用CSDN的“给分”功能了,希望别再像上次一样失败...
话说“结贴”了的话今后是不是无法再回复了?
这样很不好哎,如果这次收获了个相对不错的答案给了分,那今后不就得不到更好的答案了么?也或者下次面对更好的答案却无法给回答人分数了?


  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 2
    评论
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值