使用Windows操作系统的人有时会遇到这样的错误信息:「0X????????指令引用的0x00000000记忆体,该记忆体不能written」,然后应用程式被关闭。如果去请教一些「高手」,得到的回答往往是「Windows就是这样不稳定」之类的义愤和不屑。其实,这个错误并不一定是Windows不稳定造成的。本文就来简单分析这种错误的一般原因。
一、应用程式没有检查记忆体分配失败
程序需要一块记忆体用以储存资料时,就需要使用操作系统提供的「功能函数」来申请,如果记忆体分配成功,函数就会将所新开辟的记忆体区位址返回给应用程式,应用程式就可以通过这个位址使用这块记忆体。这就是「动态记忆体分配」,记忆体位址也就是编程中的「游标」。记忆体不是永远都招之即来、用之不尽的,有时候记忆体分配也会失败。当分配失败时系统函数会返回一个0值,这时返回值「0」已不表示新启用的游标,而是系统向应用程式发出的一个通知,告知出现了错误。作为应用程式,在每一次申请记忆体后都应该检查返回值是否为0,如果是,则意味着出现了故障,应该采取一些措施挽救,这就增强了程序的「健壮性」。若应用程式没有检查这个错误,它就会按照「思维惯性」认为这个值是给它分配的可用游标,继续在之后的执行中使用这块记忆体。真正的0位址记忆体区储存的是电脑系统中最重要的「中断描述符表」,绝对不允许应用程式使用。在没有保护机制的操作系统下(如DOS),写资料到这个位址会导致立即当机,而在健壮的操作系统中,如Windows等,这个操作会马上被系统的保护机制捕获,其结果就是由操作系统强行关闭出错的应用程式,以防止其错误扩大。这时候,就会出现上述的「写记忆体」错误,并指出被引用的记忆体位址为「0x00000000」。记忆体分配失败故障的原因很多,记忆体不够、系统函数的版本不匹配等都可能有影响。因此,这种分配失败多见于操作系统使用很长时间后,安装了多种应用程式(包括无意中「安装」的病毒程序),更改了大量的系统参数和系统档案之后。