1. This site uses cookies. By continuing to use this site, you are agreeing to our use of cookies. Learn More.
  2. Переполох Йорм Поэзия Календарь Гильдия Дайджест Календарь событий в Aion

Гайд по ошибке: Память не может быть "read"

Discussion in 'Способы решения проблем' started by FreeNecromant, Apr 26, 2010.

Thread Status:
Not open for further replies.
  1. FreeNecromant

    FreeNecromant User

    Joined:
    20.02.10
    Messages:
    2,697
    Likes Received:
    2
    ошибка чтения памяти возникает у многих пользователей, но чёткой инструкции по её устранению не существует и по сей день. я предлагаю вам ознакомиться со списком действий, которые могут помочь вам в разрешении такой проблемы. а могут и не помочь...

    весь нижеследующий текст взят из открытых интернет-источников, ссылки на которые будут приведены ниже. поиск проводился с помощью всем известных поисковых систем яндекс и google. возможные причины ошибки, помеченные как (!!!), были расценены мною как выдумка. тем не менее, у меня нет знаний\возможностей, чтобы проверить всё написанное, поэтому всерьёз (!!!) стоит рассматривать только в самом последнем случае.

    что же нам известно про ошибку "память не может быть read\written"?

    если судить по форумам, то по интернету ходит поистине огромное количество слухов, мнений и предположений на тему возникновения этой ошибки. достаточно сказать, что яндекс по запросу "память не может быть read" находит два миллиона страниц. внушительная цифра, согласитесь.

    причина возникновения ошибки довольно проста: менеджер виртуальной памяти обнаруживает попытку доступа к страницам памяти, доступ к которым не разрешён для данного процесса. но для windows ошибка эта не смертельная, поэтому вместо "синего экрана смерти" лишь выдаётся сообщение об ошибке "память не может быть...".

    если говорить упрощённо, то для каждой программы в памяти выделяется некое пространство. и если приложение начинает лезть за пределы этого пространства, т.е. пытается оттуда что-то прочитать (read) или что-то записать туда (written), то появится такая ошибка. microsoft потому и не даёт никаких рекомендаций по устранению этой ошибки, ведь это не её вина, что какие-то пользовательские программы не могут адекватно распоряжаться выданной им памятью. да-да, вы правильно поняли - виноваты криворукие разработчики игр и программ. именно из-за их ошибок вы теперь имеете счастье наблюдать "память не может быть read\written".
    "ну и пускай лезет игра за пределы памяти! мне пофиг!! хочу играть!!!" - так думает подавляющее большинство пользователей. и, в принципе, их понять можно. только вот представьте себе, что будет, если ваша любимая игрушка вылезет за пределы отведенной ей памяти и решит записать часть игрового кода в тот блок памяти, в котором сейчас находится ядро операционной системы...

    самые распространённые мнения о причинах появления этой ошибки

    1) плохая память - на многих форумах первым делом советуют проверить оперативную память (ram), но на самом деле битая память ведёт себя несколько по-иному. как правило, это либо мгновенная перезагрузка компьютера, либо просто зависание\вылет в различных приложениях. более того, зачастую даже windows не загружается в случае повреждения оперативной памяти. впрочем, в возможной причине №9 имеются советы, которые касаются оперативки, так что при желании можете попробовать повозиться с ней.

    2) вирусная атака - вирусная активность обычно проявляется несколько по-иному. зачастую это выглядит как отказ в запуске заражённых приложений, отсутствие рабочего стола (т.е. проводник\explorer.exe не запускается) или 100% загрузка процессора. узнать про возможные виды вирусов и их признаков, а также способы их лечения можно тут. но, естественно, это ещё не означает, что можно обойтись без антивируса. появилась ошибка - проверяйте комп на вирусы. особенно если раньше такой ошибки не было.

    3) отсутствие обновлений для windows - на самом деле количество установленных обновлений никак не влияет на данную ошибку. иными словами, можно установить стандартную winxp и спокойно сидеть за компьютером, а можно скачать все апдейты, которые только есть, но всё равно получать эту ошибку, хотя в интернете иногда можно встретить советы по удалению того или иного обновления. кроме того, многие пользователи ставят комплексные пакеты обновлений (более известные как service pack), которые содержат несколько сотен обновлений, что делает невозможным определение виновника.

    возможные причины ошибки "память не может быть read\written"

    возможная причина №1 - служба dep
    чаще всего можно увидеть советы по отключению службы dep (data execution prevention = предотвращение выполнения данных). для этого необходимо открыть файл c:\boot.ini и заменить в нём строку /noexecute=optin на /noexecute=alwaysoff (скриншот). для применения изменений необходимо перезагрузить компьютер. данное действие помогает где-то в 20% всех случаев. если у вас вообще нет параметра noexecute, то просто допишите его вручную (как на скриншоте).

    справка: файл boot.ini является одним из важнейших системных файлов, поэтому по умолчанию он скрыт. соответственно, для его отображения потребуется разрешить отображение скрытых и системных файлов. также его можно открыть для редактирования, если в свойствах моего компьютера выбрать вверху дополнительно и нажать кнопку "параметры" (самая нижняя). в открывшемся окне нажмите кнопку "правка", чтобы открыть boot.ini для редактирования.

    примечание: если у вас windows vista \ 7, то читайте это.

    возможная причина №2 - конфликт программного обеспечения
    проще говоря, одна из программ мешает правильно функционировать другой программе и появляется эта ошибка. понятное дело, что чёткого списка конфликтного софта не существует. тем не менее, в интернете засветился пакет norton internet security 2007, kaspersky internet security 2009, outpost firewall, k-lite mega codec pack и антивирус dr.web, а также драйвера от принтеров фирмы hewlett-packard. сюда же можно отнести и "захламленную" систему. если windows простояла полгода или больше, то вполне может появиться эта ошибка, особенно если ос активно используется, т.е. часто устанавливаются новые программы, игры и драйвера.

    если у вас лицензионная копия игры, то зайдите на диск игры и поищите там установщик directx (ну или скачайте из инета последнюю версию directx). если в вашей системе будет более старая версия directx , чем у установщика, то необходимые файлы и библиотеки будут обновлены (если версия такая же или выше, то сразу будет выведено сообщение о завершении установки).

    попробуйте также загрузиться в безопасном режиме. если там проблемное приложение запустится нормально, то значит, виновник ошибки грузится при обычной загрузке системы. про то, как можно почистить систему вообще и автозагрузку в частности, можно прочитать здесь.

    справка: при загрузке в безопасном режиме не загружаются видеодрайвера, поэтому протестировать игры в нём не получиться. если необходимо протестировать программу, использующую сеть, то выбирайте не обычный безопасный режим, а с поддержкой сети.

    возможная ошибка №3 - работа отладчика dr. watson
    в windows xp есть дебаггер под названием dr. watson. для того, чтобы отключить его, откройте реестр (пуск-выполнить: regedit) и раскройте ветку hkey_local_machine\software\microsoft\windows nt\currentversion. в ней одним из самых первых разделов будет aedebug. щёлкните по нему правой кнопкой и выберите удалить. но учтите, что данное действие не претендует на решение ошибки чтения памяти, оно может лишь убрать само сообщение об ошибке.

    возможная ошибка №4 - путь установки
    c:\ program files \ имя_разработчика \ имя_издателя \ имя_локализатора \ имя_основной_папки... признайтесь, вы ведь часто видели подобный путь при установке очередной игры? но мало кто утруждает себя тем, чтобы исправить это дикое нагромождение папок на что-нибудь более простое и понятное. однако длинный путь (да ещё и с русскими буквами) вполне может послужить причиной возникновения ошибки чтения памяти. яркий тому пример - всем известный steam. чуть ли не в половине случаев steam-игры вываливались с сообщением об ошибке чтения памяти. а всё потому, что пользователи ставили steam куда попало (например, c:\игры\программы для игр\steam вместо d:\games\steam). то же самое касается и программ. какая-то софтина вываливается с ошибкой про память? удалите её, а затем установите заново, но при этом используйте как можно более короткий путь.

    это интересно: если установка по более короткому пути не поможет, то попробуйте установить проблемное приложение на другой раздел. самому довелось наблюдать, как известный пакет для видеомонтажа pinnacle studio вываливался с ошибкой "память не может быть written" при попытке открытия видеофайлов. несмотря на то, что был установлен по нормальному пути (c:\program files\pinnacle studio). а вот когда его переустановили в e:\pinnacle studio, нормально заработал.

    возможная ошибка №5 - проблема обращения к системной библиотеке
    эта ошибка может быть связана с проблемой обращения к системной библиотеке ole32.dll, которая могла быть испорчена или разрегистрирована (например, при установке\удалении других программ). чтобы пофиксить эту возможную причину, сделайте пуск-выполнить: regsvr32 %systemroot%\system32\ole32.dll


    возможная причина №6 - попытка отправить отчёт об ошибке
    весьма оригинальный совет, в котором было сказано, что подобной ошибки (память не может быть read\written) можно избежать, если отключить в winxp отправку любых отчётов об ошибках в microsoft. в свойствах моего компьютера надо выбрать вверху дополнительно и нажать кнопку "отчет об ошибках". откроется небольшое окно. его необходимо привести вот к такому виду: View attachment 8549

    возможная причина №7 - проблемы с файлом подкачки
    рекомендуется проконтролировать обращение системы к этому файлу. для этого необходимо в свойствах моего компьютера выбрать вверху дополнительно и нажать кнопку "параметры" (самая верхняя). откроется новое окно. в нём также надо выбрать вверху дополнительно и нажать в нижней части кнопку "изменить". выделите диск, на котором хотите расположить файл подкачки (желательно, чтобы он был поменьше фрагментирован). поставьте точку напротив пункта особый размер и введите числа в поля:
    View attachment 8551

    минимальный и максимальный объём желательно выставлять одинаковым. перед выходом необходимо нажать кнопку "задать". при уменьшении\отключении файла подкачки потребуется перезагрузка. при увеличении\включении файла подкачки перезагрузка обычно не нужна. ниже будут приведены рекомендуемые значения для объёма файла подкачки в зависимости от объёма ram самого компьютера:
    512мб ram = 1536мб для файла подкачки
    1024мб ram = 1024мб для файла подкачки
    1536мб ram = 512мб для файла подкачки
    2048мб ram = 256мб для файла подкачки или вообще 0мб

    возможная причина №8 (!!!)- проблемы с оперативной памятью
    как уже говорилось выше, оперативная память обычно не является виновником возникновения ошибки "память не может быть read". тем не менее, есть рекомендации, которые имеют непосредственное отношение к оперативке, и, возможно, помогут вам убрать ошибку чтения памяти.

    во-первых, желательно использовать память от одного и того же производителя. конечно, существует множество компьютеров, в которых работает память от разных фирм, однако если у вас начала вылезать ошибка чтения памяти, а в компьютере установлены модули от разных производителей, то имеет смысл попробовать поочереди выдернуть каждый из модулей и посмотреть на результаты.

    узнать фирму-производителя каждого модуля оперативной памяти можно с помощью маленькой и бесплатной программы cpu-z (в возможной причине №11 есть её скриншот). впрочем, даже если у вас оперативная память от одной фирмы, то при наличии свободного времени можно все равно поиграться с модулями памяти (переткнуть их в свободные слоты или просто поменять местами).

    во-вторых, помните, что лучше всего устанавливать парные модули одинакового объёма. иными словами, нежелательны комбинации типа:
    1 х 1024мб + 2 х 512мб
    1 х 512мб + 2 х 256мб
    разумеется, с большой долей вероятности всё будет нормально работать, но всё-таки желательно ставить одинаковые модули. например:
    4 х 512мб
    2 х 1024мб

    важно! если вы вскроете системный блок, то можете лишиться гарантии на компьютер. перед тем, как лезть внутрь, найдите и прочитайте гарантийное соглашение. кроме того, если вы не чувствуете в себе уверенности и боитесь самостоятельно копаться во внутренностях системного блока, то доверьте это дело более опытным знакомым. дополнительную информацию по тестированию оперативной памяти можно прочитать вот тут.

    возможная причина №9 (!!!)- плохой блок питания
    ошибка чтения памяти может быть вызвана и некачественным\старым бп. конечно, это очень уж маловероятно, но наиболее идеальным вариантом будет подключение компьютера к заведомо нормальному блоку питания. если же у вас нет возможности одолжить у кого-нибудь бп, то просто отключите различную мелочь, т.е. cd\dvd-привод, карты расширения, установленные в pci-слотах, принтер и т.д.


    возможная ошибка №10 (!!!) - некорректно установленные тайминги памяти
    один из наиболее "тяжёлых" случаев*. если вкратце, то вся оперативная память построена на таймингах (задержках) чтения\записи данных. вот так выглядит стандартная оперативная память с её задержками:
    View attachment 8552

    обратите внимание, что задержки для каждой частоты разные. соответственно, если тайминги выставлены неправильно (хотя материнская плата должна делать это автоматически), то компьютер может работать, мягко говоря, нестабильно. обычно это выражается зависанием\перезагрузкой, но мне встретились предположения и том, что это тоже может вызвать ошибку "память не может быть read\written". соответственно, рекомендуется установить тайминги вручную или даже чуть-чуть повысить их. к сожалению, лишь очень малое количество пользователей (где-то 1 на 1000) способно самостоятельно выставить в bios'е правильные тайминги для своей ram. сюда же можно отнести неправильно выставленную частоту или напряжение для памяти, хотя на одном из форумов встретилось интересное сообщение: человеку помогло снижение частоты памяти.

    *сам я весьма скептически отношусь к подобному варианту возникнования ошибки чтения памяти.

    возможная ошибка №11 (!!!) - перегрев памяти
    модули ram нагреваются во время работы, но дополнительное охлаждение требуется лишь конкретным планкам памяти, которые разогнаны самим производителем и потому нуждаются в хорошем охлаждении. но обычная память (которая стоит у 95% пользователей) имеет слабое тепловыделение и нормально работает даже в плохо вентилируемых корпусах. впрочем, при желании "температурный вопрос" можно легко прояснить - достаточно просто открыть корпус и посмотреть, исчезнет ошибка или нет.

    что делать, если ничего из вышенаписанного не помогло

    на первом месте, безусловно, стоит конфликт программ\драйверов. к сожалению, даже имея в наличии полный список установленных приложений, нельзя сказать, какое из них вызывает ошибку. так что если вышеприведенные советы вам не помогли, то единственным вариантом остаётся только методичное тестирование приложений. для этого потребуется приложение\игра, которое 100% вызывает ошибку, а также чистая система.

    методика тестирования
    1) отформатировать системный раздел и установить на него ос (если не умеете, то читайте тему "как переустановить windows").
    2) создать двух пользователей, но с разными именами (например, "user-1" и "пользователь-2").
    3) запустить проблемное приложение и проверить, исчезла ли ошибка.

    примечание: для тестирования игр вам потребуется установить драйвер для видеокарты и (возможно) для звука. но помните, что больше ничего стоять не должно!

    что делать, если ошибка исчезла:
    1) устанавливаем все оставшиеся драйвера и смотрим, появилась ошибка чтения памяти или нет.
    2) устанавливаем те программы, которыми привыкли пользоваться. снова проверяем, появилась ошибка или нет.

    что делать, если ошибка не исчезла:
    1) пробуем запустить игру \ программу в другом пользователе.
    2) пробуем установить игру \ программу на другой раздел (в общем, снова пробуем все те советы, которые перечислены вверху).
    3) снова переустанавливаем систему, однако на этот раз используем более новый \ старый дистрибутив. например, вы проводили тест на winxp+sp2. значит, вам имеет смысл поискать дистрибутив winxp+sp3.

    а если я не хочу переустанавливать систему?
    дело ваше. но помните, что на данный момент это единственный вариант, который обычно помогает выявить причину ошибки чтения памяти.

    почему в сборках ошибка чтения памяти появляется чаще
    как уже неоднократно говорилось выше, ошибка чтения памяти - это ошибка программная, т.е. одна программа мешает нормально работать другой. теоретически, чем больше программ вы устанавливаете, тем выше риск появления этой ошибки. теперь проясним ситуацию со сборками. сборка - это...

    ...система, в которой имеется предустановленный софт. таким образом, ставя сборку, вы имеете все шансы подтвердить вышеупомянутую теорию, поскольку в вашей системе уже будет установлен некий софт. вы можете гарантировать, что это не он причина ошибки "память не может быть read"?

    ...система, в которую интегрированы всевозможные драйвера. учитывая то, что драйвера (см. возможную причину №2) так же, как и программы могут также вызывать ошибку чтения памяти, вы своими собственными руками повышаете шанс получения ошибки чтения памяти с момента установки сборки.

    ...система, в которой изменён интерфейс самой операционной системы. а это ещё больше усугубляет ситуацию, поскольку windows не всегда нормально переживает подобные изменения, поскольку модификации подвергаются системные файлы.

    вывод: сборка - это неизвестно как и неизвестно кем модифицированная ос. так что подумайте, имеет ли смысл ставить сборку, если проблем с этой сборкой будет больше, чем с обычной системой, а какой-то ощутимой пользы вам от сборки не будет (то, что игры и программы быстрее работают в таких сборках - миф).

    источники:
    asus.ru
    winall.ru
    nowa.cc
    3dnews.ru
    oszone.net
    softboard.ru
    drbobah.com
    ru-board.com
    microsoft.com
    home-media.ru
    stirol-it.kiev.ua
    games.north.kz

    примечание: часть информации была взята с форумов различных варез-порталов, но правилами форума игромании запрещено оставлять ссылки на подобные порталы, поэтому список источников не полный. приношу извинения тем людям, чьи сообщения были использованы в качестве источника информации без ссылки на него.

    взято с форума игромании
     
    Last edited by a moderator: Sep 8, 2012
Thread Status:
Not open for further replies.