查看: 3520|回复: 10

广州培训:内存不能“read&written”的解决方案大收集(上)

[复制链接]
发表于 2007-4-21 16:26:29 | 显示全部楼层 |阅读模式
文章摘自-----http://www.gz-benet.com.cn/bbs/Show.Asp?ID=223


内存不能“read” “written”的解决方案大收集
使用Windows操作系统的人有时会遇到这样的错误信息:“0X????????指令引用的

0x00000000内存,该内存不能written”,然后应用程序被关闭。如果去请教一些“

高手”,得到的回答往往是“Windows就是这样不稳定”之类的义愤和不屑。其实,这

个错误并不一定是Windows 不稳定造成的。本文就来简单分析这种错误的常见原因。

一、应用程序没有检查内存分配失败
  程序需要一块内存用以保存数据时,就需要调用操作系统提供的“功能函数”来

申请,如果内存分配成功,函数就会将所新开辟的内存区地址返回给应用程序,应用

程序就可以通过这个地址使用这块内存。这就是“动态内存分配”,内存地址也就是

编程中的“指针”。
  内存不是永远都招之即来、用之不尽的,有时候内存分配也会失败。当分配失败

时系统函数会返回一个0值,这时返回值“0”已不表示新启用的指针,而是系统向应

用程序发出的一个通知,告知出现了错误。作为应用程序,在每一次申请内存后都应

该检查返回值是否为0,如果是,则意味着出现了故障,应该采取一些措施挽救,这就

增强了程序的“健壮性”。
  若应用程序没有检查这个错误,它就会按照“思维惯性”认为这个值是给它分配

的可用指针,继续在之后的运行中使用这块内存。真正的0地址内存区保存的是计算机

系统中最重要的“中断描述符表”,绝对不允许应用程序使用。在没有保护机制的操

作系统下(如 DOS),写数据到这个地址会导致立即死机,而在健壮的操作系统中,

如Windows等,这个操作会马上被系统的保护机制捕获,其结果就是由操作系统强行关

闭出错的应用程序,以防止其错误扩大。这时候,就会出现上述的“写内存”错误,

并指出被引用的内存地址为“0x00000000”。
  内存分配失败故障的原因很多,内存不够、系统函数的版本不匹配等都可能有影

响。因此,这种分配失败多见于操作系统使用很长时间后,安装了多种应用程序(包

括无意中“安装”的病毒程序),更改了大量的系统参数和系统文件之后。

二、应用程序由于自身BUG引用了不正常的内存指针
  在使用动态分配的应用程序中,有时会有这样的情况出现:程序试图读写一块“

应该可用”的内存,但不知为什么,这个预料中可用的指针已经失效了。有可能是 “

忘记了”向操作系统要求分配,也可能是程序自己在某个时候已经注销了这块内存而

“没有留意”等等。注销了的内存被系统回收,其访问权已经不属于该应用程序,因

此读写操作也同样会触发系统的保护机制,企图“违法”的程序唯一的下场就是被操

作终止运行,回收全部资源。计算机世界的法律还是要比人类有效和严厉得多啊!
  像这样的情况都属于程序自身的BUG,你往往可在特定的操作顺序下重现错误。无

效指针不一定总是0,因此错误提示中的内存地址也不一定为“0x00000000”,而是其

他随机数字。
如果系统经常有所提到的错误提示,下面的建议可能会有帮助:
  1.查看系统中是否有木马或病毒。这类程序为了控制系统往往不负责任地修改系

统,从而导致操作系统异常。平常应加强信息安全意识,对来源不明的可执行程序绝

不好奇。
  2.更新操作系统,让操作系统的安装程序重新拷贝正确版本的系统文件、修正系

统参数。有时候操作系统本身也会有BUG,要注意安装官方发行的升级程序。
  3.试用新版本的应用程序。
问题
运行某些程序的时候,有时会出现内存错误的提示,然后该程序就关闭。
“0x????????”指令引用的“0x????????”内存。该内存不能为“read”。
“0x????????”指令引用的“0x????????”内存,该内存不能为“written”。
以上的情况相信大家都应该见到过,甚至说一些网友因为不爽于这个经常出现的错误

提示而屡次重装系统。相信普通用户应该不会理解那些复杂的十六进制代码。
一般出现这个现象有方面的,一是硬件,即内存方面有问题,二是软件,这就有多方

面的问题了。
故障分析
硬件方面:
一般来说,电脑硬件是很不容易坏的。内存出现问题的可能性并不大(除非你的内存

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

的检测出内存的稳定度。
假如是双内存,而且是不同品牌的内存条混插或者买了二手内存时,出现这个问题,

这时,就要检查是不是内存出问题了或者和其它硬件不兼容。
如果都没有,那就从软件方面排除故障了:
先说原理:内存有个存放数据的地方叫缓冲区,当程序把数据放在缓冲区,需要操作

系统提供的“功能函数”来申请,如果内存分配成功,函数就会将所新开辟的内存区

地址返回给应用程序,应用程序就可以通过这个地址使用这块内存。这就是“动态内

存分配”,内存地址也就是编程中的“光标”。内存不是永远都招之即来、用之不尽

的,有时候内存分配也会失败。当分配失败时系统函数会返回一个0值,这时返回值“

0”已不表示新启用的光标,而是系统向应用程序发出的一个通知,告知出现了错误。

作为应用程序,在每一次申请内存后都应该检查返回值是否为0,如果是,则意味着出

现了故障,应该采取一些措施挽救,这就增强了程序的“健壮性”。若应用程序没有

检查这个错误,它就会按照“思维惯性”认为这个值是给它分配的可用光标,继续在

之后的执行中使用这块内存。真正的0地址内存区储存的是计算机系统中最重要的“中

断描述符表”,绝对不允许应用程序使用。在没有保护机制的操作系统下(如DOS),写

数据到这个地址会导致立即当机,而在健壮的操作系统中,如Windows等,这个操作会

马上被系统的保护机制捕获,其结果就是由操作系统强行关闭出错的应用程序,以防

止其错误扩大。这时候,就会出现上述的内存不能为“read”错误,并指出被引用的

内存地址为“0x00000000“。内存分配失败故障的原因很多,内存不够、系统函数的

版本不匹配等都可能有影响。因此,这种分配失败多见于操作系统使用很长时间后,

安装了多种应用程序(包括无意中“安装”的病毒程序),更改了大量的系统参数和系

统档案之后。
(由于字数太多,无法完全转载,真不好意思)

评分

1

查看全部评分

回复

使用道具 举报

 楼主| 发表于 2007-4-21 16:27:03 | 显示全部楼层
自己先来顶一下,大家如果觉得有用的,帮我顶下,不好的地方下次我会改过来,谢谢
回复

使用道具 举报

发表于 2007-4-21 16:44:02 | 显示全部楼层
楼主,Thank you!
回复

使用道具 举报

发表于 2007-4-21 16:58:17 | 显示全部楼层
非常有用啊,我的笔记本电脑海尔H40就是,如果金山词霸2003进驻内存运行,就出现此问题。一直不知原因,也没能解决的。
回复

使用道具 举报

发表于 2007-4-21 21:35:35 | 显示全部楼层
给你们个能修复这个问题的命令,可能能行但也有不行的. for %1 in (%windir%\system32\*.dll) do regsvr32.exe /s %1
回复

使用道具 举报

发表于 2007-4-22 09:35:08 | 显示全部楼层
看了。。。试试你的方法
回复

使用道具 举报

发表于 2007-4-24 00:30:05 | 显示全部楼层
顶一下,有时候会遇到
回复

使用道具 举报

发表于 2007-4-25 11:29:17 | 显示全部楼层
不明白!~呵呵!~!~
回复

使用道具 举报

发表于 2007-4-28 23:25:01 | 显示全部楼层
顶一下
回复

使用道具 举报

发表于 2007-5-2 00:20:58 | 显示全部楼层
双核的比较多我网吧,里面有这样的问题
回复

使用道具 举报

发表于 2007-6-7 20:18:51 | 显示全部楼层
感谢lz,狂顶你的帖子。
回复

使用道具 举报

您需要登录后才可以回帖 登录 | CSNA会员注册

本版积分规则

快速回复 返回顶部 返回列表