Коды ошибок access violation at address

Иногда при запуске игры или программы возникает ошибка Access violation at address, которая сообщает о проблеме на стороне прав доступа. Но это вовсе не означает, что действуют какие-то ограничения. Причем неважно в каком виде она появилась:

  • read of address 00000000
  • in module
  • write of address
  • the bat
  • Или каком-то другом. Это все одно и то же.

В переводе на русский означает «Нарушение доступа по адресу». Но что это за проблема и как ее исправить? Давайте разбираться.

Содержание статьи

  1. Диагностика памяти
  2. Чистый запуск
  3. Удаление программ
  4. Сканирование на предмет ошибок
  5. Проверка системных компонентов
  6. Редактирование DEP
  7. Выключение UAC
  8. Другие способы решения
  9. Комментарии пользователей

Диагностика памяти

Первый шаг — запустить диагностику памяти. Есть два способа, как это сделать:

  1. Универсальный, используя утилиту Memtest.
  2. Для пользователей Windows 10 и 8. Разберем его подробнее.

В строку поиска вводим слово «памяти» и запускаем средство.

сканирование памяти

Выбираем первый пункт с пометкой «рекомендуется». Система перезагрузится и начнется сканирование.

Дождитесь завершения процедуры и посмотрите на графу «Состояние». Ошибок быть не должно. При их наличии выньте ОЗУ и протрите контакты ластиком, затем установите обратно. Если это не поможет, то замените старые планки новыми.

Чистый запуск

Предлагаю запустить компьютер в чистом режиме, чтобы узнать, не вызывает ли проблему одна из установленных программ.

Для этого:

  1. Введите msconfig в строке «Выполнить», комбинация «WIN + R».msconfig команда
  2. Переместитесь в «Службы» и скройте все от «Майкрософт». Отключите оставшиеся.отключение служб
  3. Проделайте то же самое в разделе «Автозагрузка».чистка автозагрузки
  4. Перезагрузите компьютер.

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

Удаление программ

Как говорил ранее, ошибку Access violation at address могут вызывать некоторые приложения. Чаще всего это fl studio, Artmoney, txdworkshop. Поэтому удалите лишние через деинсталлятор «Your Uninstaller» или любой другой. Желательно это делать из безопасного режима.

Если в безопасный режим войти не удается, то откройте диспетчер задач «CTRL + SHIFT + ESC», во вкладке «Процессы» найдите нужную утилиту и правым щелчком мыши откройте ее расположение. После этого удалите процесс.

skype в диспетчере задач

Теперь, находясь в этой папке удалите содержимое.

Если приложение нужно, то попробуйте переустановить его. Предварительно очистив Windows утилитой «Ccleaner».

Сканирование на предмет ошибок

Некоторые системные файлы могут отсутствовать или быть повреждены. Желательно проверить это и исправить. Делается в автоматическом режиме с помощью команд в командной строке.

DISM /Online /Cleanup-Image /RestoreHealth – нужен доступ в интернет.

sfc /scannow

dism online

Напишите их и нажмите после каждой «Enter». По завершении перезапустите ПК.

Проверка системных компонентов

Стоит убедиться, что в реестре указаны компоненты Windows, отвечающие за правильную ее работу.

Будьте осторожны при редактировании реестра, неправильные действия могут нарушить работу ОС. Действуйте четко по инструкции.

Для этого:

  1. Войдите в редактор через «WIN + R» — regedit.regedit
  2. Перейдите по пути HKLMSOFTWAREMicrosoftWindows NTCurrentVersionWinlogon и найдите два параметра: Userinit и Shell. Дважды щелкните по каждому из них. Убедитесь, что в графе «Значение» указаны правильные пути. При необходимости измените их.shell и userinit в реестре

Shell (должен ссылаться на исполняемый файл) – explorer.exe

Userinit (должен ссылаться на исполняемый файл) — C:Windowssystem32userinit.exe

По окончании перезапустите компьютер.

Редактирование DEP

Возможно, ошибку Access violation at address (in module, read of address) вызывает компонент «DEP», блокирующий в целях безопасности некоторые программы. В качестве решения предлагаю внести приложение в список исключений.

Как это сделать:

  1. Откройте «Свойства» ярлыка «Компьютер».свойства значка компьютер
  2. Перейдите в «Дополнительные параметры».дополнительные опции
  3. Во разделе «Дополнительно» щелкните по «Параметры» быстродействия.конфигурация быстродействия
  4. Зайдите в «Предотвращение выполнения» и активируйте последний параметр с пометкой «кроме выбранных ниже». Укажите нужное приложение через кнопку «Добавить».добавление exe файла в исключения dep

Выключение UAC

Большинство приложений разработанных на базе Java не работают из-за включенного контроля учетных записей, сокращенно «UAC». Давайте выключим его.

  1. Откройте классическую «Панель управления».
  2. Войдите в раздел «Учетный записи».учетные записи
  3. Щелкните по изменению контроля.настройка контроля для пользователя
  4. Передвиньте ползунок вниз до появления пометки «Никогда не уведомлять».режим без уведомлений

Другие способы решения

Если ничего не помогло, то предпримите следующие действия.

Помните, что Вы можете рассчитывать на мою помощь. Для этого напишите мне в комментариях.

Каждый, кто знаком с ОС Windows знает, что невозможно пользоваться компьютером, не столкнувшись с ошибками и проблемами. Многие из них можно решить обычной перезагрузкой системы. Но встречаются и такие, при которых невозможно продолжить работу. Одной из таких ошибок является «Access violation at address … in module». Читайте далее, как её исправить.Сообщение access violation

Содержание

  1. Причины появления ошибки Access violation at address … in module
  2. Как избавиться от ошибки обращения к памяти
  3. Проверка запуска оболочки Windows
  4. Чистка системного реестра Windows
  5. Другие методы решения ошибки «Access violation at address …»
  6. Восстановление или переустановка системы

Причины появления ошибки Access violation at address … in module

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

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

Как избавиться от ошибки обращения к памяти

Ошибка появляется при попытке выключить компьютер, перезагрузить его или поменять свой профиль. Но часто так и не удается это сделать из-за системного сообщения. Приходится либо выключить устройство из розетки, либо выключать его долгим нажатием кнопки питания Power. Перед тем, как устранять ошибку Access violation at address … in module, проверьте хранилище вирусов вашего антивирусного программного обеспечения. Возможно некоторые файлы, к которым вы пытались обратиться, были помещены сюда. Такие данные для системы будут уже не доступны.

  1. Чтобы это сделать, найдите значок на панели задач (трее) в виде стрелочки, нажмите её и появятся скрыты значки.
  2. Здесь выберите значок антивируса ПКМ.
  3. В контекстном меню обычно находится пункт «Карантин».

Пункт Карантин

Выберите его и проверьте содержимое. Если найдете там файлы программ, которым вы доверяете — удалите их из карантина. Если ошибка Access violation at address продолжается, необходимо переустановить данную программу и внести в антивирусе в список доверенных.

После этого попробуйте перезапустить компьютер и войти в ОС через последнюю удачную конфигурацию.

  1. Для этого при появления начального экрана нажмите клавишу F8 и не отпускайте до тех пор, пока не появится окно с несколькими способами запуска.
  2. Выберите «Запуск последней удачной конфигурации».
  3. В этом случае будет использована система с конфигурацией драйверов и реестра, которые работали до этого стабильно.

Пункт последняя удачная конфигурация

Выберите последнюю удачную конфигурацию в Windows

Читайте также: Указанная служба не может быть запущена, поскольку она отключена или все связанные с ней устройства отключены.

Проверка запуска оболочки Windows

Следующим шагом в исправлении ошибки Access violation at address … in module будет проверка запуска оболочки операционной системы.

  1. Откройте окно ввода команд — WIN+R.
  2. Введите следующую команду «Regedit» и подтвердите, нажав Enter.
  3. Откроются ветки, здесь выберите HKEY_LOCAL_MACHINE.
  4. Далее найдите ниже SOFTWARE.
  5. Здесь отыщите ветку Microsoft, ниже выберите Windows NT и CurrentVersion.
  6. И наконец выберите Winlogon.

Реестр ОС Windows

Когда вы откроете последнюю ветку в правой части появится окно со списком ключей и параметров, найдите здесь Shell. Его необходимо открыть как обычную папку, дважды нажав мышью. В исправной системе здесь должно быть значение Explorer.exe. Если у вас стоит иное — исправьте его и сохраните изменение. Точно так же нужно проверить ключ Userinit. Здесь по умолчанию установлено C:windowssystem32userinit.exe. Если здесь указано что-то другое — исправьте. Далее выйдите из редактора и закройте все окна. Перезагрузите компьютер и проверьте, появляется ли ошибка.

Чистка системного реестра Windows

В некоторых случаях при ошибке Ошибка Access violation at address in module помогает очистка системного реестра.

  1. Для этого вполне сгодится программ CCleaner, которую можно скачать по ссылке https://www.ccleaner.com/ru-ru.
  2. Загрузите и установите её.
  3. Откройте и выберите слева «Реестр».
  4. Нужно активировать внизу «Анализ», далее появится кнопка «Очистить».

Программа CCleaner

Иногда ошибка появляется при работе в интернете с браузера. В этом случае нужно открыть меню, найти здесь расширения и плагины, и удалить все ненужные. Если установлен плагин AddBlock, то он также может способствовать проблемам с работой некоторых приложений. Его нужно удалить. После этого нужно перезагрузить компьютер.

Другие методы решения ошибки «Access violation at address …»

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

  • выберите внизу рабочего стола «Пуск» и введите в поиске «Командная строка»;
  • в результатах выберите её ПКМ и нажмите «От имени администратора»;
  • в черном окне введите «sfc /scannow» без кавычек.Команда sfc

Будет произведена проверка файлов на жестком диске. Эта команда сканирует файловую систему жесткого диска и, если находит сбои в системных файлах автоматически исправляет их. Компьютер будет перегружен в процессе. Если этот способ снова не помог вам устранить проблему «Access violation at address … in module», попытайтесь вернуть рабочую систему при помощи точек сохранения.

  1. Снова откройте меню «Пуск», выберите поисковую строку и введите «Восстановление».
  2. В результатах найдите «Восстановление системы» — выберите его.
  3. Выберите пункт, который запустит восстановление.Окно восстановления системы
  4. В следующем окне нужно будет выбрать точку, которую система создала ранее.
  5. Выберите её и подтвердите свои действия.

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

  1. Выберите кнопку «Пуск», затем найдите справа раздел «Панель управления».
  2. В следующем окне отыщите «Восстановление или удаление программ».
  3. В списке найдите проблемное ПО и выберите кнопку «Удалить» на панели инструментов или в самом блоке (в зависимости от версии ОС).Adobe Creative Cloud в списке программ
  4. Далее вам нужно снова установить ПО из дистрибутива.

Восстановление или переустановка системы

Если ни один из методов вам не помог решить эту ошибку, попробуйте сделать восстановление с участием диска Windows.

  1. Для этого вставьте в привод диск и перезагрузите компьютер.
  2. Войдите в настройки подсистемы BIOS и выберите загрузку с дисковода.
  3. Перезагрузите компьютер и активируйте загрузку с оптического диска.
  4. После того, как будут установлены временные файлы, вы увидите окно, где предлагается переустановить систему с несколькими вариантами. Выберите «Восстановление системы».
  5. Далее найдите необходимое восстановление и нажмите «Готово».

Когда будет выполнено восстановление, проверьте наличие ошибки на компьютере. В том случае, если она снова возникает, придется переустановить Windows. Это можно сделать, не затрагивая файловый раздел жесткого диска. Это значит, что вы можете переустановить только систему на диске C:, а другие диски, где обычно хранятся файлы пользователя не трогать. После переустановки системы вы точно избавитесь от ошибки Access violation at address … in module.

Примечание для людей, заходящих сюда из поисковика: эта статья написана для разработчиков программ. Если вы не программист и не пытаетесь исправить ошибку в СВОЕЙ программе, эта статья — не для вас. До свидания. Извините, что потратил ваше время.

Примечание для студентов/новичков, пишущих на Delphi/C++ Builder: эта статья написана для диагностики исключений в вашей программе. Если вместо этого вы получаете ошибки от самой IDE (а не от вашей программы), например, access violation в пакете dclite60.bpl, то эта статья — не для вас. Чтобы решить проблемы с IDE — идите сюда. Краткий ответ: не надо использовать динозавров (Delphi 5/6/7), используйте современные IDE (Delphi XE и выше). Если всё же хочется динозавров, то часто причиной является DEP. Т.е. нужно добавить Delphi/Builder в исключения DEP. Ну или на крайний случай — отключить/удалить конфликтующий пакет.

Итак, для всех прочих (а именно: разработчиков Delphi/C++ Builder, пытающихся решить проблему возникновения исключения Access Violation в своей программе) — приступим!

Исключение класса EAccessViolation — это самое частое исключение в Delphi-программах. Я хотел бы рассмотреть, что это такое, когда возникает, и как с ним бороться. Этот пост скорее для начинающих, поэтому данные могут излагаться с упрощением.

Примечания:

  • если вы совсем начинающий или студент/студентка и получили Access Violation — первым делом включите опцию Range Check Errors (Project/Options, вкладка Compiler) и сделайте Project/Build.
  • если вы плохо или совсем не понимаете, что такое указатели и/или объекты — рекомендую сначала прочитать эту статью.
  • если вы плохо или совсем не умеете работать с отладчиком IDE (или даже не знаете, что это такое) — прочитайте сначала эту статью.

Каждая программа использует при работе память (*). Память занимает любая переменная в вашей программе. Будь это форма, компонент, массив, запись, строка или же простой Integer. Под некоторые переменные память выделяется автоматически (например, под переменные типа Integer и статические массивы), под другие — вы должны выделять её сами, явно (например, динамические массивы). Собственно, с точки зрения операционной системы каждая переменная характеризуется адресом в памяти (местоположением) и размером. Понятно, что обычно данные разных переменных не пересекаются — за исключением случаев обращением к одной области памяти через разные имена с помощью указателей.

Грубо говоря, обычно в программе используется три типа памяти: область памяти для глобальных переменных, стек и куча.

Память для глобальных переменных выделяется загрузчиком ОС при загрузке исполняемого модуля программы в память и освобождается при выгрузке модуля (выходе из программы). Глобальные переменные — это любые переменные, объявление которых располагается вне класса или процедуры. Стек используется для размещения локальных переменных (объявленных в процедуре/функции) и служебных данных (типа адресов возврата и адресов обработчиков исключений). Куча же используется для размещения динамических данных.

Подробнее.

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

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

Иногда из-за ошибок в коде программы происходит ситуация, когда программа при выполнении пытается получить доступ к памяти, которая не была выделена или уже была освобождена. Когда такое происходит, процессор возбуждает исключение класса EAccessViolation. Обычный текст ошибки в приложении Delphi — «Access violation at address XXX in module ‘YYY’. Write/read of address ZZZ» («Нарушение доступа по адресу XXX в модуле ‘YYY’. Попытка записи/чтения в ZZZ»). Хотя причина этого исключения всего одна (попытка обращения к недействительной памяти), но эта ошибка может проявлять себя в весьма разном виде и коде.

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

Ищем место возникновения Access Violation

Как, собственно, бороться с этими ошибками? Ну, если вы получили EAccessViolation под отладчиком:


То нужно просто нажать на «Break» («Ok» в старых версиях Delphi) и отладчик сразу же ткнёт вас на строчку с ошибкой. Также можно посмотреть стек вызовов (в меню Delphi — View/Debug windows/Call Stack):


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

Иными словами, отладчик сразу же тыркает вас в строку с ошибкой.

Если же вы используете средства автоматической диагностики типа EurekaLog/madExcept, то вместо обычного сообщения об ошибке вы получите баг-отчёт, в котором будет виден тот же самый Call Stack (вид стека вызова может отличаться из-за различных методов его получения):


Не имеет значения, столкнулись ли вы с проблемой во время отладки или получили баг-отчёт от EurekaLog для уже распространяемой программы — хорошо бы подготовиться к этой ситуации заранее и включить опции проекта, упрощающие отладку. Как правило, это опции «Use Debug DCUs» и «Stack frames».

Окей, найти место ошибки — это только пол-дела. Определить почему же в этой строке возникла ошибка — это вторые пол-дела.

Ищем причину возникновения Access Violation анализом кода

Если ситуация возникла у вас в отладчике, то тут всё относительно просто: вам нужно установить точку останова на проблемную строчку и проверить значения всех переменных и выражений, участвующих в ней — вот вам и причина ошибки, находится сразу же. Я не буду подробно останавливаться на теме отладки здесь, более подробно об этом написано в моей статье, часть 2 (осторожно: большой размер).

В случае, если у вас на руках есть только баг-репорт, а не ситуация под отладчиком, то вам придётся использовать свои телепатические способности, которые обычно развиваются с опытом. Дабы помочь вам в этом, здесь я как-раз и хочу рассмотреть типичные причины возникновения ошибки Access Violation.

1. Во-первых, это всевозможные ошибки выхода за границы массивов. Например, типичная ошибка новичка может выглядеть так:

var
  X: Integer;
...
  for X := 1 to Length(List) do // ошибка! Должно быть: for X := 0 to Length(List) - 1 do
  begin
    // ... делаем что-то с List[X]
  end;

Если в вашей проблемной строке есть скобочки типа [], то у вас есть хороший довод к проверке допустимости выражения в [].

Обычно такие ошибки нужно отлавливать на стадии отладки, включая опцию Range Check Errors. Дело в том, что подобные ошибки весьма опасны тем, что могут пройти незамеченными (и потом редко ловятся при эксплуатации программы), даже более того — они могут разрушить стек, так что нельзя будет получить место возникновения ошибки. Но об этом позже.

2. Различного рода неверные передачи параметров. Обычно эти ошибки отлавливаются во время разработки и тестирования, нежели во время эксплуатации программы. Чаще всего они возникают при использовании процедур с нетипизированными параметрами. Сюда же относятся различные варианты ошибок переполнения буфера, например:

var
  S1: array of Integer;
  S2: String;
...
  // Неверно:
  Stream.ReadBuffer(S1, 256);     // портит указатель S1
  // Правильно:
  Stream.ReadBuffer(S1[0], 256);  // читает данные из потока в массив

  // Неверно:
  FillChar(S2, Length(S2), 0);            // портит указатель S2
  // Правильно:
  FillChar(Pointer(S2)^, Length(S2), 0);  // очищает строку, забивая её данные нулями

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

3. Передачи данных между двумя менеджерами памяти. Обычно ошибки такого плана возникают при передаче данных из DLL в приложение или наоборот. а также между двумя DLL. Чаще всего новички любят передавать из/в DLL строки типа String.

Причины этого я рассматривал ранее. Эти ошибки обычно отлавливаются немедленно во время разработки программы и очень редко доживают до рабочей программы. Решаются эти проблемы правильным проектированием.

4. Неверное объявление функций, импортируемых из DLL. Наиболее часто путают модель вызова. Если у вас получается EAccessViolation при вызове функции из DLL — просто внимательно посмотрите на её объявление и убедитесь, что её сигнатура верна — чаще всего пропускают модель вызова, stdcall или cdecl.

Хотя обычно ошибки такого плана отлавливаются на этапе разработки, тем не менее могут быть ситуации, когда ошибка проползает в готовую программу. Вот увлекательная история Реймонда Чена о том, как программа может работать с неверно объявленным прототипом функции (довольно интересны и посты в серии до и после этого).

5. Отсутствие синхронизации при работе с потоками. Если вы делаете программу с использованием нескольких потоков, то у вас могут быть проблемы, если вы не обеспечили необходимой синхронизации. Например, любые обращения к VCL запрещены из вторичных потоков — вам нужно использовать Synchronize. Собственно, проблемы тут возникают, когда один поток меняет данные с которыми работает второй поток — что для последнего становится полной неожиданностью.

К сожалению, ошибки с синхронизацией потоков наиболее тяжело диагностировать. Лучшее, что вы можете сделать — прогарантировать, что такие проблемы никогда не возникнут: используйте Synchronize и/или заключайте код в критические секции при работе с разделяемыми потоками переменными. Иногда проблемы возникают из-за использования CreateThread вместо BeginThread или TThread (из-за отсутствия установки IsMultiThreaded).

6. Вызовы функций или процедур по процедурной переменной, когда она содержит неверное значение. Например:

var
  Lib1, Lib2: HMODULE;
  Proc: procedure;
...
  Lib1 := LoadLibrary('MyDll.dll');         // один код загрузил библиотеку. Быть может - другой поток
  ...
  Lib2 := GetModuleHandle('MyDll.dll');    
  Proc := GetProcAddress(Lib2, 'MyProc');   // нет проверки на ошибку. Функции может не быть - тогда Proc будет равна nil
  Proc;                                     // Proc может быть равна nil - будет Access Violation
  ...
  FreeLibrary(Lib1);                        // ещё какой-то код выгрузил библиотеку
  ...
  Proc;                                     // хотя Proc <> nil, код, на который она указывает,
                                            // больше не загружен - здесь будет AV.

Ситуация очень сильно напоминает следующий пункт и бороться с нею нужно такими же методами.

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

Проблема в том, что при освобождении компонента, его ссылка-переменная не меняется, продолжая указывать на уже удалённую память. Кроме того, локальные переменные не инициализируются автоматически при входе в процедуру и содержат мусор. Вот пример подобного рода ошибок:

var
  Str: TStringList;
...
  Str.Add('S'); // Ошибка! Мы забыли создать объект вызовом Str := TStringList.Create;
  ...
  Str := TStringList.Create;
  Str.Add('S');
  ...
  Str.Free; // Здесь мы удалили объект, но ссылка Str по-прежнему указывает на ту же область памяти
  ...
  if Str.Count > 0 then // Ошибка! Обращение к уже удалённому объекту

Как мы уже говорили ранее, в приложениях Delphi есть служебный код, называемый «менеджером памяти», который отвечает за выделение и освобождение памяти в вашей программе и служит прослойкой между низкоуровневыми функциями операционной системы и вашим кодом. При всей своей пользе менеджер памяти, однако, добавляет в программу одну проблему: из-за него в программе находится куски памяти, которые выделены с точки зрения операционной системы, но свободны с точки зрения программы. Например, удалили вы компонент, но менеджер памяти не отдаёт память системе немедленно, придерживая её для дальнейшего использования.

Поэтому все ошибки доступа к памяти опасны в первую очередь тем, что могут пройти незамеченными. Например, мы обращаемся к уже удалённому объекту, но поскольку менеджер памяти ещё не отдал эту память системе, то обращение может пройти успешно. Чуть ранее мы говорили, что для предотвращения таких ситуаций вам нужно использовать FreeAndNil и другие механизмы. Ситуация ещё хуже с локальными массивами: дело в том, что локальные массивы размещаются в стеке, в котором обычно есть довольно большие участки размещённой памяти по краям массива. Что ещё хуже, эта память обычно реально используется программой (в отличие от памяти, которую мы освободили при удалении объекта), так что вы можете, спокойно промахнувшись, записать что-то не туда, и в итоге, ошибка всплывёт в совершенно другом месте из-за испорченных данных. Чтобы сделать ситуацию ещё хуже: в стеке хранятся и служебные данные программы, необходимые для её выполнения — это адреса возврата и обработчики исключений.

Например:

procedure TForm13.Button1Click(Sender: TObject);
var
  S: array [0..1] of Integer;
  I: Integer;
begin
  I := 2;           // предположим, что это значение как-то вычисляется и
                    // из-за ошибки в программе получает неверное значение
  S[I] := 0;        // эта строка затрёт адрес возврата из Button1Click в стеке
end;                // в этой строке произойдёт Access Violation, т.к. мы испортили адрес возврата

procedure TForm13.Button2Click(Sender: TObject);
var
  S: array [0..1] of Integer;
  I: Integer;
begin
  I := -6;          // пусть мы снова ошиблись в I
  try
    S[I]     := 1;  // вместо массива мы стираем обработчик исключений, установленный try
    S[I + 1] := 2;
    S[I + 2] := 3;
    Abort;          // полный вылет программы, т.к. менеджер исключений обнаружил испорченный стек
  except
    ShowMessage('Aborted');
  end;
end;

procedure TForm13.Button3Click(Sender: TObject);
var
  S: array [0..1] of Integer;
  I: Integer;
begin
  I := -1;          // пусть мы снова ошиблись в I
  S[I] := 1;        // хотя мы снова портим стек, но нам это сходит с рук
                    // никакого EAccessViolation не будет вовсе!
end;

Весьма коварные ситуации, не правда ли? В зависимости от того, как именно мы ошибёмся в индексе массива, мы можем получить (**):
а). Программу, выдающую правильные результаты.
б). Программу, выдающую неверные результаты.
в). Программу, возбуждающую исключение.
г). Программу, вылетающую вообще.
Причём одна и та же программа с таким багом может показывать любое из этих поведений, смотря по тому, на какой машине она запущена и в каких условиях/окружении выполняется.

Вот почему чрезвычайно важно использовать опцию Range Check Errors во время разработки и тестирования.
Ну, вы можете также включить её и для release-версии кода, если не уверены в качестве своей стадии тестирования.

Итак, что, собственно, нужно сделать, когда мы получили Access Violation? Ну, с помощью предыдущего пункта мы находим строку с ошибкой, а дальше пытаемся по пунктам подставить возможные причины:
— Есть в строке []? — подумаем, а не может ли у нас быть неверный индекс?
— Есть работа с объектами? Проследим, какова логика работы — не удаляется ли объект раньше времени?
— Используем DLL? А правильно ли объявлена функция? А уж не обмениваемся ли мы динамическими данными (строками, там, массивами)?
и т.д.

Существенную помощь в таком анализе нам поможет следующий пункт.

Ищем причину возникновения Access Violation анализом данных

Во-первых, мы можем попытаться вытащить информацию из самого сообщения об ошибке. Напомним его вид:

Access violation at address XXX in module ‘YYY’. Write/read of address ZZZ.

Во-первых, адрес XXX указывает на точное место в программе, где произошла ошибка. Именно по этому адресу отладчик Delphi и EurekaLog ищут строчку для показа её вам. Также модуль, которому она принадлежит, показывается в сообщении как YYY. Обычно это ваша программа, DLL или системная DLL. Однако, иногда это может быть и совершенно левое значение. Например, если в сообщении не указан модуль или значение XXX выглядит подозрительно (меньше $400000 или больше $7FFFFFFF), то у вас либо проблемы с перезаписью стека (пункт «в» в конце предыдущего раздела), либо вызов неверной функции (пункт 6 или, иногда, 4 из предыдущего раздела).

Следующий полезный кусок информации — это слово «write» или «read». Первое означает, что возникла проблема при записи информации, второе — что проблема была при чтении. Соответственно, вам нужно проверять в строке кода либо операции записи, либо операции чтения. Например, если проблемная строка была «P := W;«, то вам нужно обратить внимание на P, если в сообщении стоит «write». Если же там стоит «read», то нужно проверять, что же у нас с W.

И последний кусок информации, который можно извлечь из сообщения — это ZZZ. Собственно, точное значение нас обычно не волнует. Важен только факт — велико оно или мало. Мало — это что-то типа $00000000, $0000000A, $00000010 и т.п. Большие значения — это, например, $00563F6A, $705D7800 и др. Если ZZZ мало, то у вас идёт обращение по ссылке равной nil. Если оно велико, то у вас идёт обращение по ненулевой, но мусорной ссылке. В первом случае вам нужно искать, зачем же вы полезли по ссылке равной nil (или кто же освободил переменную раньше времени), во втором случае вам нужно понять, кто же это такой освободил объект, а ссылку не занулил. Короче говоря, это значение (так же, как и с «write»/»read») помогает сузить область поиска.

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



На первой вкладке вы можете видеть ассемблерный листинг своей программы. Приводится он здесь только для удобства — чтобы не надо было лезть ещё куда-то, чтобы подсмотреть его. Никакой информации он не несёт. А вот на второй вкладке вы можете видеть состояние регистров, (части) стека и (части) памяти в момент исключения. В данном случае мы смотрим на ассемблерный листинг и видим, что в проблемной команде участвуют регистры eax и edx. По вкладке CPU мы находим, что eax равен 0, что означает, что мы пытаемся присвоить значение по указателю, равному nil. Взглянув на строчку исходника, которую мы узнали из стека вызовов, мы узнаем имя переменной. Вот вам и причина: переменная оказалась равна nil.

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

В следующий раз мы поговорим о ситуациях, когда у вас в коде есть ошибка, но никакого исключения не возбуждается. Частично мы уже говорили об этом здесь (например, пункт «1» и пункты «а»-«б» в конце второго раздела). Но в следующий раз мы пойдём чуть дальше и посмотрим, что ещё можно сделать для отлова таких ситуаций. И, в любом случае, у вас всегда есть возможность переписать код ;)

Читать дальше.

См. также: как читать баг-отчёты.

Примечания:
(*) Очень подробно о памяти для приложений рассказывает Марк Руссинович.
(**) Вот ещё один пример, как один и тот же код может демонстировать широкий диапазон поведений.

Содержание

  1. Bloggik.net
  2. Bloggik.net
  3. Ошибка Access violation at address и способы решения
  4. Причины возникновения и разновидности
  5. Способы решение ошибки
  6. Исправляем ошибку Access violation at address – инструкция
  7. Диагностика памяти
  8. Чистый запуск
  9. Удаление программ
  10. Сканирование на предмет ошибок
  11. Проверка системных компонентов
  12. Редактирование DEP
  13. Выключение UAC
  14. Другие способы решения

Bloggik.net

Главная >> Проблемы и решения >> Windows >> Windows XP. Сообщение об ошибке «Access violation at address. ». Что делать?

Пытаетесь запустить только что установленную программу или игру и видите на экране сообщение об ошибке «Access violation at address. » . Не знаете, что делать? Давайте найдем решение вместе.

Сообщение об ошибке «Access violation at address. » означает, что приложение пытается обратиться к тому разделу памяти, что не предназначен для работы с данной программой. Причин , вызывающих появление ошибки «Access violation at address. » великое множество, от работы вредоносных программ (куда уж без вирусов) и до сбоев программного обеспечения.

Наиболее действенный способ избавиться от появления сообщение об ошибке «Access violation at address. » — это изменить настройки Data Execution Prevention или просто DEP . Не вдаваясь в подробности, можно сказать, что DEP — это функция безопасности, предназначенная для обеспечения невозможности запуска вредоносного кода, причем, как на программном, так и на аппаратном уровне.

Решение 1. Добавление программ в список исключений.
Вызовите контекстное меню , кликнув правой кнопкой мыши по иконке Мой компьютер , далее Свойства , и вкладка « Дополнительно » → пункт « Быстродействие » → кнопка Параметры → вкладка « Предотвращение выполнения данных ». Отметьте пункт « Включить DEP для всех программ и служб, кроме выбранных ниже ». Затем при помощи кнопки « Добавить » включите в список программы, вызывающие появление надоедливой ошибки «Access violation at address. » . После чего нажмите « Применить » → ОК .

Решение 2. Отключение DEP.
Щелкните правой кнопкой по иконке Мой компьютер , затем Свойства , и вкладка « Дополнительно » → пункт « Загрузка и восстановление » – кнопка Параметры → кнопка Правка . Отредактируйте последнюю строчку в файле boot.ini следующим образом:
Было:
multi(0)disk(0)rdisk(0)partition(1)WINDOWS=»Microsoft Windows XP Professional RU» /noexecute=optin /fastdetect
Стало:
multi(0)disk(0)rdisk(0)partition(1)WINDOWS=»Microsoft Windows XP Professional RU» /noexecute=alwaysoff /fastdetect
Или просто откройте скрытый файл boot.ini (обычно расположен на диске С) и отредактируйте его указанным способом.
Сохраните измененный файл boot.ini и выполните перезагрузку операционной системы .
Таким образом, можно настроить DEP и иначе, используя четыре команды: OptIn , OptOut , AlwaysOn или AlwaysOff , но это тема для отдельной статьи.

Как видите, ничего сложного. Удачной работы!

Источник

Bloggik.net

Главная >> Проблемы и решения >> Windows >> Windows 7. Сообщение об ошибке «Access violation at address. ». Что делать?

Windows 7. Сообщение об ошибке «Access violation at address. ». Что делать?

Только что установили новую операционную систему Windows 7 , инсталлировали свои любимые приложения и теперь пытаетесь их запустить? И вместо интерфейса программ видите сообщение об ошибке «Access violation at address. » или даже «. память не может быть «read» либо «. память не может быть «written», а также «Прекращена работа программы ХХХХХХ. » ? Растерялись? Не знаете, что делать? Давайте найдем выход вместе.

К возникновению этих ошибок могут приводить разнообразные сбои функционирования операционной системы как вызванные вирусами, так и конфликтом драйверов и другого программного обеспечения.
Наиболее надежный способ навсегда избавиться от ошибки «Access violation at address. » — это самостоятельно настроить DEP ( Data Execution Prevention ) или, выражаясь по-русски, ПВД ( Предотвращение Выполнения Данных ).

Решение 1. Желательное. Изменение настроек DEP.
Нажмите правой кнопкой мыши по ярлыку « Мой компьютер » и перейдите в пункт « Свойства », после чего откройте « Дополнительные параметры системы ». На вкладке « Дополнительно » в пункте « Быстродействие » нажмите на кнопку « Параметры » — вкладка « Предотвращение выполнения данных ». Выберите «Включить DEP для всех программ и служб , кроме выбранных ниже» и, воспользовавшись кнопкой « Добавить… », сформируйте список программ, вызвавших появление одной из ошибок «Access violation at address. » , «. память не может быть «read» , «. память не может быть «written» или «Прекращена работа программы ХХХХХХ. » . После чего кликните по кнопке « Применить » → ОК .

Решение 2. Нежелательное. Отключение DEP.
Нежелательное, поскольку DEP включена в Windows 7 совсем не зря и помогает предотвращать запуск вредоносного кода.
Вызовите команду выполнить , воспользовавшись комбинацией клавиш Win+R , и введите команду cmd, затем нажмите Enter . В открывшейся на экране монитора командной строке наберите следующую строчку bcdedit.exe /set nx AlwaysOff и нажмите кнопку Enter . После появления сообщения системы о том, что операция успешно выполнена, перезагрузите операционную систему Windows 7 . Теперь если вы вновь зайдете на вкладку « Предотвращение выполнения данных », то увидите, что инструменты для работы с DEP стали неактивны. Больше сообщения об ошибках появляться не должны.

Как видите, ничего сложного. Удачной работы!

Источник

Ошибка Access violation at address и способы решения

Основная проблема с которой сталкиваются пользователи ПК — является «синий экран смерти». Его появление может свидетельствовать о проблемах с исполняемыми системными файлами которые подверглись изменениям или перезаписыванию. Решение возникших сложностей не всегда можно назвать простыми. Одни решаются буквально за пару минут, а у других следует определить корень. Исходя из информации которую нам предоставляет Windows, мы следует процедуре восстановления повреждённых объектов файловой системы. Некоторые ради экономии времени или по незнанию начинают полную переустановку, но мы с Вами попытаемся решить ошибку без данной процедуры.

Причины возникновения и разновидности

Нам хотелось бы выделить основные текстовые и кодовые представления ошибки встречаемые пользователями. В большинстве случаев помогает полная переустановка системы. Данная процедура решит большинство проблем, при перезаписи исполняемых файлов. Замена битых файлов совершенно новыми — один из вариантов решения.

Основной причиной возникновения можно назвать нарушение целостности системы. При рассмотрении ошибки «Access violation» мы взяли за исходные материалы сами исполняемые процессы. При детальном рассмотрении можно обнаружить, что процесс обращается к .dll файлам у которых затёрты заголовоки. В результате мы видим на экране «Access violation at address $ (где символ $ — код процесса) in module«. Определение причины по коду можно сделать из панели администрирования Windows.

Дополнительной серьезной причиной могут служить битые секторы в которые при дефрагментации были записаны корневые файлы. Обычно это драйвера или .dll-ки папки Виндовс.

Способы решение ошибки

Нам потребуется заняться восстановлением целостности системы. Хорошо поможет специальная команда встроенная в операционную систему. Для ее вызова, следуем инструкции:

  1. Нажимаем WIN+R для открытия диалогового окна ввода команды.
  2. Пишем команду cmd и нажимаем ОК.
  3. На экране отобразится терминал работы с системой:
  4. Вводим команду «sfc/scannow«.
  5. Нам предложат перезагрузить систему для исправления ошибок.
  6. Перезапускаемся и ничего не нажимаем. Начнется автоматическая проверка целостности файлов.
  7. После запуска, вновь заходим в терминал и вводим команду «chkdsk C: /f /r«. Она проверит жесткие диски на битые секторы и заблокирует их, предварительно перенеся файлы в безопасное место.
  8. Ошибка Access violation at address должна исчезнуть.

Второй способ заключается в стандартных действиях которые каждый пользователь должен выполнять ежедневно.

  1. Займитесь проверкой и обновлением системы до последней версии.
  2. Обновите драйвера видеокарт, если Access violation появляется при запуске игры.
  3. Исполняемые файлы VC++ должны быть в актуальном состоянии. Скачать можно с официального сайта Microsoft.
  4. Произведите дефрагментацию диска С. Это поможет перенести данные в рабочие секторы жесткого диска (если у вас SSD, то пропускаем шаг).

Источник

Исправляем ошибку Access violation at address – инструкция

Иногда при запуске игры или программы возникает ошибка Access violation at address, которая сообщает о проблеме на стороне прав доступа. Но это вовсе не означает, что действуют какие-то ограничения. Причем неважно в каком виде она появилась:

  • read of address 00000000
  • in module
  • write of address
  • the bat
  • Или каком-то другом. Это все одно и то же.

В переводе на русский означает «Нарушение доступа по адресу». Но что это за проблема и как ее исправить? Давайте разбираться.

Диагностика памяти

Первый шаг — запустить диагностику памяти. Есть два способа, как это сделать:

  1. Универсальный, используя утилиту Memtest.
  2. Для пользователей Windows 10 и 8. Разберем его подробнее.

В строку поиска вводим слово «памяти» и запускаем средство.

Выбираем первый пункт с пометкой «рекомендуется». Система перезагрузится и начнется сканирование.

Дождитесь завершения процедуры и посмотрите на графу «Состояние». Ошибок быть не должно. При их наличии выньте ОЗУ и протрите контакты ластиком, затем установите обратно. Если это не поможет, то замените старые планки новыми.

Чистый запуск

Предлагаю запустить компьютер в чистом режиме, чтобы узнать, не вызывает ли проблему одна из установленных программ.

  1. Введите msconfig в строке «Выполнить», комбинация «WIN + R».
  2. Переместитесь в «Службы» и скройте все от «Майкрософт». Отключите оставшиеся.
  3. Проделайте то же самое в разделе «Автозагрузка».
  4. Перезагрузите компьютер.

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

Удаление программ

Как говорил ранее, ошибку Access violation at address могут вызывать некоторые приложения. Чаще всего это fl studio, Artmoney, txdworkshop. Поэтому удалите лишние через деинсталлятор «Your Uninstaller» или любой другой. Желательно это делать из безопасного режима.

Если в безопасный режим войти не удается, то откройте диспетчер задач «CTRL + SHIFT + ESC», во вкладке «Процессы» найдите нужную утилиту и правым щелчком мыши откройте ее расположение. После этого удалите процесс.

Теперь, находясь в этой папке удалите содержимое.

Если приложение нужно, то попробуйте переустановить его. Предварительно очистив Windows утилитой «Ccleaner».

Сканирование на предмет ошибок

Некоторые системные файлы могут отсутствовать или быть повреждены. Желательно проверить это и исправить. Делается в автоматическом режиме с помощью команд в командной строке.

DISM /Online /Cleanup-Image /RestoreHealth – нужен доступ в интернет.

Напишите их и нажмите после каждой «Enter». По завершении перезапустите ПК.

Проверка системных компонентов

Стоит убедиться, что в реестре указаны компоненты Windows, отвечающие за правильную ее работу.

Будьте осторожны при редактировании реестра, неправильные действия могут нарушить работу ОС. Действуйте четко по инструкции.

  1. Войдите в редактор через «WIN + R» — regedit.
  2. Перейдите по пути HKLMSOFTWAREMicrosoftWindows NTCurrentVersionWinlogon и найдите два параметра: Userinit и Shell. Дважды щелкните по каждому из них. Убедитесь, что в графе «Значение» указаны правильные пути. При необходимости измените их.

Shell (должен ссылаться на исполняемый файл) – explorer.exe

Userinit (должен ссылаться на исполняемый файл) — C:Windowssystem32userinit.exe

По окончании перезапустите компьютер.

Редактирование DEP

Возможно, ошибку Access violation at address (in module, read of address) вызывает компонент «DEP», блокирующий в целях безопасности некоторые программы. В качестве решения предлагаю внести приложение в список исключений.

Как это сделать:

  1. Откройте «Свойства» ярлыка «Компьютер».
  2. Перейдите в «Дополнительные параметры».
  3. Во разделе «Дополнительно» щелкните по «Параметры» быстродействия.
  4. Зайдите в «Предотвращение выполнения» и активируйте последний параметр с пометкой «кроме выбранных ниже». Укажите нужное приложение через кнопку «Добавить».

Выключение UAC

Большинство приложений разработанных на базе Java не работают из-за включенного контроля учетных записей, сокращенно «UAC». Давайте выключим его.

  1. Откройте классическую «Панель управления».
  2. Войдите в раздел «Учетный записи».
  3. Щелкните по изменению контроля.
  4. Передвиньте ползунок вниз до появления пометки «Никогда не уведомлять».

Другие способы решения

Если ничего не помогло, то предпримите следующие действия.

Помните, что Вы можете рассчитывать на мою помощь. Для этого напишите мне в комментариях.

Источник

Access Violation — это косяки с доступом к памяти. Попытка чтения/записи туда, куда вы писать не можете (в вашем случае вы читаете память по адрему $FFFFFFE4).

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

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

Понравилась статья? Поделить с друзьями:
  • Коды ошибок abs скания 4 серии
  • Коды ошибок abs ниссан примера р12
  • Коды ошибок abs камаз 5490
  • Коды ошибок abs газон некст
  • Коды ошибок abs газ валдай