出现应用程序正常初始化(0xc0000034)失败,该如何解决?

2025-01-04 02:48:48
推荐回答(6个)
回答1:

应用程序错误,0X000000该内存不能为read written的解决方法

出现这个现象有方面的,一是硬件,即内存方面有问题,二是软件,这就有多方面的问题了。

一:先说说硬件:

一般来说,电脑硬件是很不容易坏的。内存出现问题的可能性并不大(除非你的内存真的是杂牌的一塌徒地),主要方面是:1。内存条坏了(二手内存情况居多)、2。使用了有质量问题的内存,3。内存插在主板上的金手指部分灰尘太多。4。使用不同品牌不同容量的内存,从而出现不兼容的情况。5。超频带来的散热问题。你可以使用MemTest 这个软件来检测一下内存,它可以彻底的检测出内存的稳定度。

二、如果都没有,那就从软件方面排除故障了。

先说原理:内存有个存放数据的地方叫缓冲区,当程序把数据放在缓冲区,需要操作系统提供的“功能函数”来申请,如果内存分配成功,函数就会将所新开辟的内存区地址返回给应用程序,应用程序就可以通过这个地址使用这块内存。这就是“动态内存分配”,内存地址也就是编程中的“光标”。内存不是永远都招之即来、用之不尽的,有时候内存分配也会失败。当分配失败时系统函数会返回一个0值,这时返回值“0”已不表示新启用的光标,而是系统向应用程序发出的一个通知,告知出现了错误。作为应用程序,在每一次申请内存后都应该检查返回值是否为0,如果是,则意味着出现了故障,应该采取一些措施挽救,这就增强了程序的“健壮性”。若应用程序没有检查这个错误,它就会按照“思维惯性”认为这个值是给它分配的可用光标,继续在之后的执行中使用这块内存。真正的0地址内存区储存的是计算机系统中最重要的“中断描述符表”,绝对不允许应用程序使用。在没有保护机制的操作系统下(如DOS),写数据到这个地址会导致立即当机,而在健壮的操作系统中,如Windows等,这个操作会马上被系统的保护机制捕获,其结果就是由操作系统强行关闭出错的应用程序,以防止其错误扩大。这时候,就会出现上述的内存不能为“read”错误,并指出被引用的内存地址为“0x00000000“。内存分配失败故障的原因很多,内存不够、系统函数的版本不匹配等都可能有影响。因此,这种分配失败多见于操作系统使用很长时间后,安装了多种应用程序(包括无意中“安装”的病毒程序),更改了大量的系统参数和系统档案之后。

在使用动态分配的应用程序中,有时会有这样的情况出现:程序试图读写一块“应该可用”的内存,但不知为什么,这个预料中可用的光标已经失效了。有可能是“忘记了”向操作系统要求分配,也可能是程序自己在某个时候已经注销了这块内存而“没有留意”等等。注销了的内存被系统回收,其访问权已经不属于该应用程序,因此读写操作也同样会触发系统的保护机制,企图“违法”的程序唯一的下场就是被操作终止执行,回收全部资源。计算机世界的法律还是要比人类有效和严厉得多啊!像这样的情况都属于程序自身的BUG,你往往可在特定的操作顺序下重现错误。无效光标不一定总是0,因此错误提示中的内存地址也不一定为“0x00000000”,而是其它随机数字。

回答2:

这是读取阿里旺旺出错 阿里旺旺在装下

回答3:

重新装一遍阿里旺旺

回答4:

文件不完全,缺少支持文件.一些软件安装失败就经常这样,一般都是注册表出问题,软件重装下!或重新下载个

回答5:

8.11发布新变种查杀方法,地址
http://forum.ikaka.com/topic.asp?board=28&artid=8351280
这个问题是由一个叫做ghost.pif的U盘病毒导致的
关于分析我在
http://hi.baidu.com/newcenturysun/blog/item/b6c822d192f160399a502775.html
已经给出
不过最新变种的病毒会查询以下注册表项的某些键值来获取相关安全软件的安装目录,在获得安装目录下生成以系统文件名"ws2_32.dll"命名的文件夹,从而使
相关安全软件运行失败。
SOFTWARE\\rising\\Rav
SOFTWARE\\Kingsoft\\AntiVirus
SOFTWARE\\JiangMin
SOFTWARE\KasperskyLab\InstalledProducts\Kaspersky
Anti-Virus
Personal
SOFTWARE\\KasperskyLab\\SetupFolders
SOFTWARE\Network
Associates\TVD\Shared
Components\Framework
SOFTWARE\Eset\Nod\CurrentVersion\Info
SOFTWARE\\Symantec\\SharedUsage
SOFTWARE\Microsoft\Windows\CurrentVersion\App
Paths\360safe.exe
因为这些安全软件运行时候会加载ws2_32.dll
ws2_32.dll正确的位置是在system32下面
而软件通常寻找dll的方法是首先从自己的文件夹中寻找
那么病毒通过在这些软件的文件夹里创建一个伪造的ws2_32.dll从而导致软件启动时加载这个伪造的ws2_32.dll
导致启动失败!
解决方法如下:
1.安全模式下(开机后不断
按F8键
然后出来一个高级菜单
选择第一项
安全模式
进入系统)
打开sreng
启动项目
注册表
删除如下项目
<{0CB68AD9-FF66-3E63-636B-B693E62F6236}>
[Microsoft
Corporation]
双击我的电脑,工具,文件夹选项,查看,单击选取"显示隐藏文件或文件夹"
并清除"隐藏受保护的操作系统文件(推荐)"前面的钩。在提示确定更改时,单击“是”
然后确定
右键点击
右键菜单中的打开
打开C盘
删除
C:\Program
Files\Internet
Explorer\romdrivers.bak
C:\Program
Files\Internet
Explorer\romdrivers.bkk
C:\Program
Files\Internet
Explorer\romdrivers.dll
2.清空C:\DOCUME~1\用户名\LOCALS~1\Temp下面所有内容
3.右键点击
右键菜单中的打开
打开其他分区
删除autorun.inf和ghost.pif

回答6:

.....有些文件..不能移....C是系统盘吧?..有些文件是映射涵数一个性质的...你这样破坏了它的路径....要没事那才见鬼了...建议把文件移回去..不行还原下