該內(nèi)存不能為“read”的原因是什么
該內(nèi)存不能為“read”的原因是在是太多太多了,只要是Windows系統(tǒng),只要是X86或者現(xiàn)在64位也不例外,都會(huì)出現(xiàn)這種問題.這是一個(gè)BUG或者是文件錯(cuò)誤導(dǎo)致.
運(yùn)行某些程序的時(shí)候,有時(shí)會(huì)出現(xiàn)內(nèi)存錯(cuò)誤的提示,然后該程序就關(guān)閉。
“0x????????”指令引用的“0x????????”內(nèi)存。該內(nèi)存不能為“read”。
“0x????????”指令引用的“0x????????”內(nèi)存,該內(nèi)存不能為“written”。
不知你出現(xiàn)過類似這樣的故障嗎?(0x后面內(nèi)容有可能不一樣。)
一般出現(xiàn)這個(gè)現(xiàn)象有方面的,一是硬件,即內(nèi)存方面有問題,二是軟件,這就有多方面的問題了。
1、微軟IE緩沖溢出漏洞引起
2、內(nèi)存或虛擬內(nèi)存地址使用沖突造成
程序的運(yùn)行需要分配一定的內(nèi)存地址給程序使用,當(dāng)程序結(jié)束時(shí)釋放留出空間讓給新的程序使用,win是多任務(wù)的系統(tǒng) 有時(shí)前程序未結(jié)束 又有新的任務(wù)開始 到底要多少內(nèi)存或虛擬內(nèi)存來保證我們同時(shí)運(yùn)行的工作任務(wù)呢?也許win在這個(gè)問題上沒弄好,所以有此錯(cuò)誤常常發(fā)生,一般運(yùn)行大型軟件或多媒體后出現(xiàn)這種情況
3、劣質(zhì)內(nèi)存條也會(huì)出現(xiàn)這個(gè)問題
一般來說,內(nèi)存出現(xiàn)問題的可能性并不大,主要方面是:內(nèi)存條壞了、內(nèi)存質(zhì)量有問題,還有就是2個(gè)不同牌子不同容量的內(nèi)存混插,也比較容易出現(xiàn)不兼容的情況,同時(shí)還要注意散熱問題,特別是超頻后。你可以使用MemTest 這個(gè)軟件來檢測(cè)一下內(nèi)存,它可以徹底的檢測(cè)出內(nèi)存的穩(wěn)定度。
假如你是雙內(nèi)存,而且是不同品牌的內(nèi)存條混插或者買了二手內(nèi)存時(shí),出現(xiàn)這個(gè)問題,這時(shí),你就要檢查是不是內(nèi)存出問題了或者和其它硬件不兼容。
4、微軟WINDOWS系統(tǒng)的漏洞
windows把內(nèi)存地址0X00000000到0X0000ffff指定為分配null指針的地址范圍,如果程序試圖訪問這一地址,則認(rèn)為是錯(cuò)誤。c/c++編寫的程序通常不進(jìn)行嚴(yán)格的錯(cuò)誤檢查,當(dāng)采用malloc來分配內(nèi)存而可供分配的地址空間不夠的情況下返回null指針。但是代碼不檢查這種錯(cuò)誤,認(rèn)為地址分配已經(jīng)成功,于是就訪問0X00000000的地址,于是就發(fā)生內(nèi)存違規(guī)訪問,同時(shí)該進(jìn)程被終止。
5、可能沒有完全正確安裝apache服務(wù),且啟動(dòng)了它的原故; 把服務(wù)中的 OracleOraHomeXXHTTPServer改成停止
6、應(yīng)用程序沒有檢查內(nèi)存分配失敗
程序需要一塊內(nèi)存用以保存數(shù)據(jù)時(shí),就需要調(diào)用操作系統(tǒng)提供的“功能函數(shù)”來申請(qǐng),如果內(nèi)存分配成功,函數(shù)就會(huì)將所新開辟的內(nèi)存區(qū)地址返回給應(yīng)用程序,應(yīng)用程序就可以通過這個(gè)地址使用這塊內(nèi)存。這就是“動(dòng)態(tài)內(nèi)存分配”,內(nèi)存地址也就是編程中的“指針”。
內(nèi)存不是永遠(yuǎn)都招之即來、用之不盡的,有時(shí)候內(nèi)存分配也會(huì)失敗。當(dāng)分配失敗時(shí)系統(tǒng)函數(shù)會(huì)返回一個(gè)0值,這時(shí)返回值“0”已不表示新啟用的指針,而是系統(tǒng)向應(yīng)用程序發(fā)出的一個(gè)通知,告知出現(xiàn)了錯(cuò)誤。作為應(yīng)用程序,在每一次申請(qǐng)內(nèi)存后都應(yīng)該檢查返回值是否為0,如果是,則意味著出現(xiàn)了故障,應(yīng)該采取一些措施挽救,這就增強(qiáng)了程序的“健壯性”。
若應(yīng)用程序沒有檢查這個(gè)錯(cuò)誤,它就會(huì)按照“思維慣性”認(rèn)為這個(gè)值是給它分配的可用指針,繼續(xù)在之后的運(yùn)行中使用這塊內(nèi)存。真正的0地址內(nèi)存區(qū)保存的是計(jì)算機(jī)系統(tǒng)中最重要的“中斷描述符表”,絕對(duì)不允許應(yīng)用程序使用。在沒有保護(hù)機(jī)制的操作系統(tǒng)下(如DOS),寫數(shù)據(jù)到這個(gè)地址會(huì)導(dǎo)致立即死機(jī),而在健壯的操作系統(tǒng)中,如Windows等,這個(gè)操作會(huì)馬上被系統(tǒng)的保護(hù)機(jī)制捕獲,其結(jié)果就是由操作系統(tǒng)強(qiáng)行關(guān)閉出錯(cuò)的應(yīng)用程序,以防止其錯(cuò)誤擴(kuò)大。這時(shí)候,就會(huì)出現(xiàn)上述的“寫內(nèi)存”錯(cuò)誤,并指出被引用的內(nèi)存地址為“0x00000000”。
內(nèi)存分配失敗故障的原因很多,內(nèi)存不夠、系統(tǒng)函數(shù)的版本不匹配等都可能有影響。因此,這種分配失敗多見于操作系統(tǒng)使用很長(zhǎng)時(shí)間后,安裝了多種應(yīng)用程序(包括無意中“安裝”的病毒程序),更改了大量的系統(tǒng)參數(shù)和系統(tǒng)文件之后。
7、應(yīng)用程序由于自身BUG引用了不正常的內(nèi)存指針
在使用動(dòng)態(tài)分配的應(yīng)用程序中,有時(shí)會(huì)有這樣的情況出現(xiàn):程序試圖讀寫一塊“應(yīng)該可用”的內(nèi)存,但不知為什么,這個(gè)預(yù)料中可用的指針已經(jīng)失效了。有可能是“忘記了”向操作系統(tǒng)要求分配,也可能是程序自己在某個(gè)時(shí)候已經(jīng)注銷了這塊內(nèi)存而“沒有留意”等等。注銷了的內(nèi)存被系統(tǒng)回收,其訪問權(quán)已經(jīng)不屬于該應(yīng)用程序,因此讀寫操作也同樣會(huì)觸發(fā)系統(tǒng)的保護(hù)機(jī)制,企圖“違法”的程序唯一的下場(chǎng)就是被操作終止運(yùn)行,回收全部資源。計(jì)算機(jī)世界的法律還是要比人類有效和嚴(yán)厲得多啊!
像這樣的情況都屬于程序自身的BUG,你往往可在特定的操作順序下重現(xiàn)錯(cuò)誤。無效指針不一定總是0,因此錯(cuò)誤提示中的內(nèi)存地址也不一定為“0x00000000”,而是其他隨機(jī)數(shù)字。
關(guān)鍵詞:內(nèi)存,read
閱讀本文后您有什么感想? 已有 人給出評(píng)價(jià)!
- 1
- 119
- 1
- 1
- 2
- 1