TA的每日心情 | 开心 2014-7-28 21:47 |
---|
签到天数: 2 天 [LV.1]初来乍到
|
“0x????????”指令引用的“0x????????”内存$ H" K9 O7 Q- A: w- d
0 p" e ^/ ^5 W
运行某些程序的时候,有时会出现内存错误的提示,然后该程序就关闭。 4 Z9 A: {: A* {- w: q
2 A5 X, f( }+ s/ k“0x????????”指令引用的“0x????????”内存。该内存不能为“read”。 " \# K8 q$ m1 w% |
0 I9 Y6 N& {4 L2 |* C9 }
“0x????????”指令引用的“0x????????”内存,该内存不能为“written”。 0 c+ t& j( h3 [1 T! M! @4 Y
6 i U0 k: d- {# a( t
以上的情况相信大家都应该见到过,甚至说一些网友因为不爽于这个经常出现的错误提示而屡次重装系统。相信普通用户应该不会理解那些复杂的十六进制代码。 & h3 w. U3 _# c' ]
+ O" G7 h C Q9 N# ^0 N4 }2 Z
出现这个现象有方面的,一是硬件,即内存方面有问题,二是软件,这就有多方面的问题了。 & H% L* r8 ?9 _9 i9 b
7 f" Y: x5 j5 b& U4 m" K1 _
一:先说说硬件: 7 w7 U$ N; \6 |6 x$ Y; u( m3 y) X
/ R' d- P7 P: A! Q
一般来说,电脑硬件是很不容易坏的。内存出现问题的可能性并不大(除非你的内存真的是杂牌的一塌徒地),主要方面是:1。内存条坏了(二手内存情况居多)、2。使用了有质量问题的内存,3。内存插在主板上的金手指部分灰尘太多。4。使用不同品牌不同容量的内存,从而出现不兼容的情况。5。超频带来的散热问题。你可以使用MemTest 这个软件来检测一下内存,它可以彻底的检测出内存的稳定度。 ( [2 t1 x C' ^6 f7 u
5 P; v. |3 K, z. h- J二、如果都没有,那就从软件方面排除故障了。
" D: Q1 O6 r& F% {6 c( c _$ j$ P8 j: a, O* Q1 t% v
先说原理:内存有个存放数据的地方叫缓冲区,当程序把数据放在缓冲区,需要操作系统提供的“功能函数”来申请,如果内存分配成功,函数就会将所新开辟的内存区地址返回给应用程序,应用程序就可以通过这个地址使用这块内存。这就是“动态内存分配”,内存地址也就是编程中的“光标”。内存不是永远都招之即来、用之不尽的,有时候内存分配也会失败。当分配失败时系统函数会返回一个0值,这时返回值“0”已不表示新启用的光标,而是系统向应用程序发出的一个通知,告知出现了错误。作为应用程序,在每一次申请内存后都应该检查返回值是否为0,如果是,则意味着出现了故障,应该采取一些措施挽救,这就增强了程序的“健壮性”。若应用程序没有检查这个错误,它就会按照“思维惯性”认为这个值是给它分配的可用光标,继续在之后的执行中使用这块内存。真正的0地址内存区储存的是计算机系统中最重要的“中断描述符表”,绝对不允许应用程序使用。在没有保护机制的操作系统下(如DOS),写数据到这个地址会导致立即当机,而在健壮的操作系统中,如Windows等,这个操作会马上被系统的保护机制捕获,其结果就是由操作系统强行关闭出错的应用程序,以防止其错误扩大。这时候,就会出现上述的内存不能为“read”错误,并指出被引用的内存地址为“0x00000000“。内存分配失败故障的原因很多,内存不够、系统函数的版本不匹配等都可能有影响。因此,这种分配失败多见于操作系统使用很长时间后,安装了多种应用程序(包括无意中“安装”的病毒程序),更改了大量的系统参数和系统档案之后。
2 T. g% ~( [! {$ o- B
3 M H( ^ j+ z' S. T在使用动态分配的应用程序中,有时会有这样的情况出现:程序试图读写一块“应该可用”的内存,但不知为什么,这个预料中可用的光标已经失效了。有可能是 “忘记了”向操作系统要求分配,也可能是程序自己在某个时候已经注销了这块内存而“没有留意”等等。注销了的内存被系统回收,其访问权已经不属于该应用程序,因此读写操作也同样会触发系统的保护机制,企图“违法”的程序唯一的下场就是被操作终止执行,回收全部资源。计算机世界的法律还是要比人类有效和严厉得多啊!像这样的情况都属于程序自身的BUG,你往往可在特定的操作顺序下重现错误。无效光标不一定总是0,因此错误提示中的内存地址也不一定为 “0x00000000”,而是其它随机数字。
) K4 E2 M* G' r1 j& S9 K8 i- J, v [" A* [2 y! Z% | r8 ~
首先建议:
* {9 M, M' c% a2 w- @; A1 g' f4 d2 u% S v1 R. w* ~
1、 检查系统中是否有木马或病毒。这类程序为了控制系统往往不负责任地修改系统,从而导致操作系统异常。平常应加强信息安全意识,对来源不明的可执行程序绝不好奇。 3 d& W/ X( E/ {5 @/ c: A) ~
) [: X2 f1 Z3 ]8 a2 z" U& }& r
2、 更新操作系统,让操作系统的安装程序重新拷贝正确版本的系统档案、修正系统参数。有时候操作系统本身也会有BUG,要注意安装官方发行的升级程序。
7 u ] c8 ~- v7 c, X
( l, c: \+ ^" w) x( ?# N“0x????????”指令引用的“0x????????”内存
4 @$ O+ C6 }9 N: M6 p$ x" j3 X. F: L
3、 尽量使用最新正式版本的应用程序、Beta版、试用版都会有BUG。
; L( m4 z. F3 ]. j' n
, ^2 [0 F6 a+ q1 I9 K4、 删除然后重新创建 Winnt\System32\Wbem\Repository 文件夹中的文件:在桌面上右击我的电脑,然后单击管理。在"服务和应用程序"下,单击服务,然后关闭并停止 Windows Management Instrumentation 服务。 删除 Winnt\System32\Wbem\Repository 文件夹中的所有文件。(在删除前请创建这些文件的备份副本。)打开"服务和应用程序",单击服务,然后打开并启动 Windows Management Instrumentation 服务。当服务重新启动时,将基于以下注册表项中所提供的信息重新创建这些文件: HKEY_LOCAL_MACHINE\SOFTWARE\Microsoft\WBEM\CIMOM\Autorecover MOFs # T4 w h0 z- B+ K" L& U
7 Z$ E1 h% t1 c f$ n& O2 s
下面搜集几个例子给大家分析:
4 C$ V, P" W. a9 J% M
! [# E$ m* i) k! b例一:IE浏览器出现“0x0a8ba9ef”指令引用的“0x03713644” 内存,或者“0x70dcf39f”指令引用的“0x00000000”内存。该内存不能为“read”。要终止程序,请单击“确定”的信息框,单击“确定”后,又出现“发生内部错误,您正在使用的其中一个窗口即将关闭”的信息框,关闭该提示信息后,IE浏览器也被关闭。解决方法:
% B6 _ Z* y+ |# L& v9 p2 T
. w+ g5 x5 i. ^1 }: g1、 开始-运行窗口,输入“regsvr32 actxprxy.dll”回车,接着会出现一个信息对话 框“DllRegisterServer in actxprxy.dll succeeded”,确定。再依次运行以下命令。(这个方法有人说没必要,但重新注册一下那些.dll对系统也没有坏处,反正多方下手,能解决问题就行。)
' g5 z4 o, {2 f* h5 v% w
8 r3 H- y( q4 l4 Zregsvr32 shdocvw.dll ( @5 W" r1 ?; B. F
- C+ `. k+ W' I' V+ O4 E4 X
regsvr32 oleaut32.dll " M/ s8 E. e* p$ X# |) p) |$ c
+ I9 ~* @$ b5 f: X# b. q2 `/ _4 ~& u
regsvr32 actxprxy.dll 8 I9 e: c% x7 W7 \- z
& [. ^1 d9 l) l6 D' ]3 T `' oregsvr32 mshtml.dll
9 I2 C1 j, Z2 y" g% }3 R' }5 r- l2 E) W2 g! b2 m- N% z
regsvr32 msjava.dll / \: B' D( F+ c: T7 i8 _# a4 t. O+ ]
$ s- H% c5 o3 H k3 H9 ]: u# r
regsvr32 browseui.dll
0 f# }* t+ s- W+ G A6 e8 J U0 W# J
regsvr32 urlmon.dll
' D. ~+ D4 v/ p0 S) w
$ k" P6 A& n8 y* j8 o" n& D2、 修复或升级IE浏览器,同时打上系统补丁。看过其中一个修复方法是,把系统还原到系统初始的状态下。建议将IE升级到了6.0。 / `8 ^; t& I' z) O
+ V0 ^7 B2 w7 \0 l- o例二:有些应用程序错误: “0x7cd64998” 指令参考的 “0x14c96730” 内存。该内存不能为 “read”。解决方法:Win XP的“预读取”技术这种最佳化技术也被用到了应用程序上,系统对每一个应用程序的前几次启动情况进行分析,然后新增一个描述套用需求的虚拟“内存映像”,并把这些信息储存到Windows\Prefetch文件夹。一旦建立了映像,应用软件的装入速度大大提高。XP的预读取数据储存了最近8次系统启动或应用软件启动的信息。建议将虚拟内存撤换,删除Windows\Prefetch目录下所有*.PF文件,让windows重新收集程序的物理地址。
( E* `7 |" Y* H& @2 O; m) C' c' ~) Y+ |9 s3 K; a0 R
例三:在XP下双击光盘里面的“AutoRun.exe”文件,显示“0x77f745cc”指令引用的“0x00000078”内存。该内存不能为 “written”,要终止程序,请单击“确定”,而在Windows 98里运行却正常。解决方法:这可能是系统的兼容性问题,winXP的系统,右键“AutoRun.exe”文件,属性,兼容性,把“用兼容模式运行这个程序”项选择上,并选择“Windows 98/Me”。win2000如果打了SP的补丁后,只要开始,运行,输入:regsvr32 c:\winnt\apppatch\slayerui.dll。右键,属性,也会出现兼容性的选项。 7 N0 T2 m0 Y7 ]
8 ~& T3 p5 P' a* q0 e
例四:RealOne Gold关闭时出现错误,以前一直使用正常,最近却在每次关闭时出现“0xffffffff”指令引用的“0xffffffff”内存。该内存不能为 “read” 的提示。解决方法:当使用的输入法为微软拼音输入法2003,并且隐藏语言栏时(不隐藏时没问题)关闭RealOne就会出现这个问题,因此在关闭RealOne 之前可以显示语言栏或者将任意其他输入法作为当前输入法来解决这个问题。
% `( _; X0 W) |9 m7 D6 Y
" S! {/ M# Q4 X( K1 f/ i4 ` V例五:我的豪杰超级解霸自从上网后就不能播放了,每次都提示“0x060692f6”(每次变化)指令引用的“0xff000011”内存不能为 “read”,终止程序请按确定。解决方法:试试重装豪杰超级解霸,如果重装后还会,到官方网站下载相应版本的补丁试试。还不行,只好换就用别的播放器试试了。 - ]( Q- }9 g* c% a: o9 }0 [
% {% q7 ~3 J- D4 G L' i
例六:双击一个游戏的快捷方式,“0x77f5cd0”指令引用“0xffffffff”内 存,该内存不能为“read” ,并且提示Client.dat程序错误。解决方法:重装显卡的最新驱动程序,然后下载并且安装DirectX9.0。
8 A5 m/ H$ S) a, U! l: Y6 p Z7 w+ }
3 L3 ^* Y G9 h, h) e8 q% u例七:一个朋友发信息过来,我的电脑便出现了错误信息:“0x772b548f”指令引用的“0x00303033”内存,该内存不能为 “written”,然后QQ自动下线,而再打开QQ,发现了他发过来的十几条的信息。解决方法:这是对方利用QQ的BUG,发送特殊的代码,做QQ出错,只要打上补丁或升级到最新版本,就没事了。
2 G( [2 {- x/ q4 G |
|