Иногда при запуске игры или программы возникает ошибка Access violation at address, которая сообщает о проблеме на стороне прав доступа. Но это вовсе не означает, что действуют какие-то ограничения. Причем неважно в каком виде она появилась:
- read of address 00000000
- in module
- write of address
- the bat
- Или каком-то другом. Это все одно и то же.
В переводе на русский означает «Нарушение доступа по адресу». Но что это за проблема и как ее исправить? Давайте разбираться.
Содержание статьи
- Диагностика памяти
- Чистый запуск
- Удаление программ
- Сканирование на предмет ошибок
- Проверка системных компонентов
- Редактирование DEP
- Выключение UAC
- Другие способы решения
- Комментарии пользователей
Диагностика памяти
Первый шаг — запустить диагностику памяти. Есть два способа, как это сделать:
- Универсальный, используя утилиту Memtest.
- Для пользователей Windows 10 и 8. Разберем его подробнее.
В строку поиска вводим слово «памяти» и запускаем средство.
Выбираем первый пункт с пометкой «рекомендуется». Система перезагрузится и начнется сканирование.
Дождитесь завершения процедуры и посмотрите на графу «Состояние». Ошибок быть не должно. При их наличии выньте ОЗУ и протрите контакты ластиком, затем установите обратно. Если это не поможет, то замените старые планки новыми.
Чистый запуск
Предлагаю запустить компьютер в чистом режиме, чтобы узнать, не вызывает ли проблему одна из установленных программ.
Для этого:
- Введите msconfig в строке «Выполнить», комбинация «WIN + R».
- Переместитесь в «Службы» и скройте все от «Майкрософт». Отключите оставшиеся.
- Проделайте то же самое в разделе «Автозагрузка».
- Перезагрузите компьютер.
Если это устранило неполадку, то снова активируйте программы и отключайте их по одной, чтобы выявить неисправную. Часто сбой вызывают антивирусы, блокируя в целях безопасности некоторые приложения.
Удаление программ
Как говорил ранее, ошибку Access violation at address могут вызывать некоторые приложения. Чаще всего это fl studio, Artmoney, txdworkshop. Поэтому удалите лишние через деинсталлятор «Your Uninstaller» или любой другой. Желательно это делать из безопасного режима.
Если в безопасный режим войти не удается, то откройте диспетчер задач «CTRL + SHIFT + ESC», во вкладке «Процессы» найдите нужную утилиту и правым щелчком мыши откройте ее расположение. После этого удалите процесс.
Теперь, находясь в этой папке удалите содержимое.
Если приложение нужно, то попробуйте переустановить его. Предварительно очистив Windows утилитой «Ccleaner».
Сканирование на предмет ошибок
Некоторые системные файлы могут отсутствовать или быть повреждены. Желательно проверить это и исправить. Делается в автоматическом режиме с помощью команд в командной строке.
DISM /Online /Cleanup-Image /RestoreHealth – нужен доступ в интернет.
sfc /scannow
Напишите их и нажмите после каждой «Enter». По завершении перезапустите ПК.
Проверка системных компонентов
Стоит убедиться, что в реестре указаны компоненты Windows, отвечающие за правильную ее работу.
Будьте осторожны при редактировании реестра, неправильные действия могут нарушить работу ОС. Действуйте четко по инструкции.
Для этого:
- Войдите в редактор через «WIN + R» — regedit.
- Перейдите по пути HKLMSOFTWAREMicrosoftWindows NTCurrentVersionWinlogon и найдите два параметра: Userinit и Shell. Дважды щелкните по каждому из них. Убедитесь, что в графе «Значение» указаны правильные пути. При необходимости измените их.
Shell (должен ссылаться на исполняемый файл) – explorer.exe
Userinit (должен ссылаться на исполняемый файл) — C:Windowssystem32userinit.exe
По окончании перезапустите компьютер.
Редактирование DEP
Возможно, ошибку Access violation at address (in module, read of address) вызывает компонент «DEP», блокирующий в целях безопасности некоторые программы. В качестве решения предлагаю внести приложение в список исключений.
Как это сделать:
- Откройте «Свойства» ярлыка «Компьютер».
- Перейдите в «Дополнительные параметры».
- Во разделе «Дополнительно» щелкните по «Параметры» быстродействия.
- Зайдите в «Предотвращение выполнения» и активируйте последний параметр с пометкой «кроме выбранных ниже». Укажите нужное приложение через кнопку «Добавить».
Выключение UAC
Большинство приложений разработанных на базе Java не работают из-за включенного контроля учетных записей, сокращенно «UAC». Давайте выключим его.
- Откройте классическую «Панель управления».
- Войдите в раздел «Учетный записи».
- Щелкните по изменению контроля.
- Передвиньте ползунок вниз до появления пометки «Никогда не уведомлять».
Другие способы решения
Если ничего не помогло, то предпримите следующие действия.
Помните, что Вы можете рассчитывать на мою помощь. Для этого напишите мне в комментариях.
Каждый, кто знаком с ОС Windows знает, что невозможно пользоваться компьютером, не столкнувшись с ошибками и проблемами. Многие из них можно решить обычной перезагрузкой системы. Но встречаются и такие, при которых невозможно продолжить работу. Одной из таких ошибок является «Access violation at address … in module». Читайте далее, как её исправить.
Содержание
- Причины появления ошибки Access violation at address … in module
- Как избавиться от ошибки обращения к памяти
- Проверка запуска оболочки Windows
- Чистка системного реестра Windows
- Другие методы решения ошибки «Access violation at address …»
- Восстановление или переустановка системы
Причины появления ошибки Access violation at address … in module
Данная ошибка может возникать, когда процесс обращается не к тому типу памяти или она не предназначена для использования этого приложения. Она может возникать при запуске игр, использовании любых программ или медиа проигрывателей. Этому может способствовать как сбой в самой системе и архитектуре файлов на диске, так и при влиянии вирусного программного обеспечения. Часто еще этот сбой возникает, когда пользователь пытается открыть файл или обратиться к нему, но по адресу его нет.
Ошибку могут спровоцировать программы, которые были разработаны неумелыми программистами. Чтобы не сталкиваться с этой проблемой, нужно скачивать программное обеспечение только с официальных сайтов.
Как избавиться от ошибки обращения к памяти
Ошибка появляется при попытке выключить компьютер, перезагрузить его или поменять свой профиль. Но часто так и не удается это сделать из-за системного сообщения. Приходится либо выключить устройство из розетки, либо выключать его долгим нажатием кнопки питания Power. Перед тем, как устранять ошибку Access violation at address … in module, проверьте хранилище вирусов вашего антивирусного программного обеспечения. Возможно некоторые файлы, к которым вы пытались обратиться, были помещены сюда. Такие данные для системы будут уже не доступны.
- Чтобы это сделать, найдите значок на панели задач (трее) в виде стрелочки, нажмите её и появятся скрыты значки.
- Здесь выберите значок антивируса ПКМ.
- В контекстном меню обычно находится пункт «Карантин».
Выберите его и проверьте содержимое. Если найдете там файлы программ, которым вы доверяете — удалите их из карантина. Если ошибка Access violation at address продолжается, необходимо переустановить данную программу и внести в антивирусе в список доверенных.
После этого попробуйте перезапустить компьютер и войти в ОС через последнюю удачную конфигурацию.
- Для этого при появления начального экрана нажмите клавишу F8 и не отпускайте до тех пор, пока не появится окно с несколькими способами запуска.
- Выберите «Запуск последней удачной конфигурации».
- В этом случае будет использована система с конфигурацией драйверов и реестра, которые работали до этого стабильно.
Читайте также: Указанная служба не может быть запущена, поскольку она отключена или все связанные с ней устройства отключены.
Проверка запуска оболочки Windows
Следующим шагом в исправлении ошибки Access violation at address … in module будет проверка запуска оболочки операционной системы.
- Откройте окно ввода команд — WIN+R.
- Введите следующую команду «Regedit» и подтвердите, нажав Enter.
- Откроются ветки, здесь выберите HKEY_LOCAL_MACHINE.
- Далее найдите ниже SOFTWARE.
- Здесь отыщите ветку Microsoft, ниже выберите Windows NT и CurrentVersion.
- И наконец выберите Winlogon.
Когда вы откроете последнюю ветку в правой части появится окно со списком ключей и параметров, найдите здесь Shell. Его необходимо открыть как обычную папку, дважды нажав мышью. В исправной системе здесь должно быть значение Explorer.exe. Если у вас стоит иное — исправьте его и сохраните изменение. Точно так же нужно проверить ключ Userinit. Здесь по умолчанию установлено C:windowssystem32userinit.exe. Если здесь указано что-то другое — исправьте. Далее выйдите из редактора и закройте все окна. Перезагрузите компьютер и проверьте, появляется ли ошибка.
Чистка системного реестра Windows
В некоторых случаях при ошибке Ошибка Access violation at address in module помогает очистка системного реестра.
- Для этого вполне сгодится программ CCleaner, которую можно скачать по ссылке https://www.ccleaner.com/ru-ru.
- Загрузите и установите её.
- Откройте и выберите слева «Реестр».
- Нужно активировать внизу «Анализ», далее появится кнопка «Очистить».
Иногда ошибка появляется при работе в интернете с браузера. В этом случае нужно открыть меню, найти здесь расширения и плагины, и удалить все ненужные. Если установлен плагин AddBlock, то он также может способствовать проблемам с работой некоторых приложений. Его нужно удалить. После этого нужно перезагрузить компьютер.
Другие методы решения ошибки «Access violation at address …»
Далее нужно попытаться восстановить файлы, которые возможно были удалены самим пользователем, антивирусами или вирусам. Для этого понадобится дистрибутив с текущей операционной системой Windows. Вставьте его в привод и следуйте дальнейшей инструкции:
- выберите внизу рабочего стола «Пуск» и введите в поиске «Командная строка»;
- в результатах выберите её ПКМ и нажмите «От имени администратора»;
- в черном окне введите «sfc /scannow» без кавычек.
Будет произведена проверка файлов на жестком диске. Эта команда сканирует файловую систему жесткого диска и, если находит сбои в системных файлах автоматически исправляет их. Компьютер будет перегружен в процессе. Если этот способ снова не помог вам устранить проблему «Access violation at address … in module», попытайтесь вернуть рабочую систему при помощи точек сохранения.
- Снова откройте меню «Пуск», выберите поисковую строку и введите «Восстановление».
- В результатах найдите «Восстановление системы» — выберите его.
- Выберите пункт, который запустит восстановление.
- В следующем окне нужно будет выбрать точку, которую система создала ранее.
- Выберите её и подтвердите свои действия.
В этом случае система также будет перезагружена и возвращена к состоянию сохраненной точки. Проверьте, возникает ли сейчас ошибка. В тексте данной ошибки часто указан модуль и программа, с которой возникают проблемы. Найдите эту программу на своем компьютере и удалите её, а затем заново установите. Это можно сделать в панели управления.
- Выберите кнопку «Пуск», затем найдите справа раздел «Панель управления».
- В следующем окне отыщите «Восстановление или удаление программ».
- В списке найдите проблемное ПО и выберите кнопку «Удалить» на панели инструментов или в самом блоке (в зависимости от версии ОС).
- Далее вам нужно снова установить ПО из дистрибутива.
Восстановление или переустановка системы
Если ни один из методов вам не помог решить эту ошибку, попробуйте сделать восстановление с участием диска Windows.
- Для этого вставьте в привод диск и перезагрузите компьютер.
- Войдите в настройки подсистемы BIOS и выберите загрузку с дисковода.
- Перезагрузите компьютер и активируйте загрузку с оптического диска.
- После того, как будут установлены временные файлы, вы увидите окно, где предлагается переустановить систему с несколькими вариантами. Выберите «Восстановление системы».
- Далее найдите необходимое восстановление и нажмите «Готово».
Когда будет выполнено восстановление, проверьте наличие ошибки на компьютере. В том случае, если она снова возникает, придется переустановить Windows. Это можно сделать, не затрагивая файловый раздел жесткого диска. Это значит, что вы можете переустановить только систему на диске C:, а другие диски, где обычно хранятся файлы пользователя не трогать. После переустановки системы вы точно избавитесь от ошибки Access violation at address … in module.
When you install a software program, whether that’s a video game, word processing application, or a media player, you expect it to work when you launch it and stay working when in use. Unfortunately, if you have corrupted software or memory that is damaged, you may find that you are unable to access certain pieces of software as you normally would.
When access is denied, you end up with an access violation error, which often reads “Exception_Access_Violation” with an error code or address attached. In some cases, this error may pop up with a specific module that’s causing the problem or provide the name of the software causing the issue.
What is the Access Violation at Address Error, and Why Does it Pop Up?
The access violation at address error is Windows-specific and can occur on all operating system versions, including Windows 10. If you have been getting this error, it means that the software you are attempting to launch or run is trying to access a protected memory address. When this occurs, the attempt to access the protected memory is denied, as the program you are trying to run should not have access to this particular address except for the program that is currently using it.
How to Read the Numeric Error Code?
In most cases, the error will be accompanied by a numeric code that is between 7-10 digits in length. For example, 0xC0000005 is a broad access violation error that prevents users from playing audio or accessing the control panel. When you see a numeric error code pop up, you can debug it by reading the exception parameters (the letter and numbers). The first exception parameter (0) will tell you the type of violation, the second exception parameter (1) will tell you the address. You can use this code to identify the cause of the problem and potentially the fix for it as well.
To help you with your access violation at address error, we’ve compiled 9 easy to try solutions below.
1. Inspect Your Computer for a Malware Infection.
If any of your software is heavily infected with malware, it can corrupt your memory systems which can cause this error to pop up. If you’ve noticed your computer acting up before getting an access violation at address error, such as unprovoked alerts or fake browser windows, then a detailed and deep scan should be done. If you’re just using the built-in antivirus software and it doesn’t find anything, you may want to try another option to see if a malware infection was missed. Getting rid of the malware will solve the issue.
2. Add Your Program to an Exception Access List.
If you have no malware on your computer, you can add the program that you want to run to a data execution prevention exception list. This will allow you to run the program despite the error code. Here is how to do this.
- In your computer’s search bar, type in “control panel” and open it.
- You’ll want the system choice here.
- Click into system and security.
- In the system menu, click on the advanced system settings.
- In the advanced tab, find the performance section and hit settings.
- Across the top, click onto the data executive prevention tab.
- The section option will allow you to turn on data execution prevention for all programs and services except those that you choose.
- Click the add button and find your program’s .exe file.
- Add it to the list, hit apply, and then okay to save the changes.
Run the program again and check to see if you still get the access violation at address error.
3. Consider Disabling User Account Control.
If you are trying to install or run a Java-based program, the access violation at address is more likely to occur. To fix this issue, you can temporarily disable the user account control to fix the error from coming up. This does have a slight security risk to it, so if you are uncomfortable with this method, disable user account control when you run your desired application and then turn it back on.
- In your computer’s search bar, type in “control panel” and open it.
- Find the “user accounts” and click into it – twice.
- Choose the last option, which is to change the settings of the user account controls.
- This window allows you to set when you get notified about changes to your computer. Move the slider down to “never notify” and hit okay.
- Try running your program now.
If your program runs, just remember to fix your user account settings once you are done with it for the day.
4. Double Check Your Software Isn’t in Read-Only Mode.
If your program is in a read-only mode, access is going to be denied and it won’t be able to launch or run effectively. Here is how to check this and fix it.
- Find the shortcut on your desktop and right-click on the file.
- Choose the properties option from the menu.
- Find the “general” tab located at the top of the window.
- Find the attributes section and make sure read-only is not checked.
- If it is checked, uncheck it.
- Hit apply/okay to save changes.
If your program does not have a desktop shortcut, you can either make one and follow the same steps or right-click on the .exe application file and follow the above steps.
5. Check Your RAM for Corruption.
If you ever had a heavy malware infection on your computer and it managed to cause damage to portions of your random access memory (RAM), then this could be the cause behind your access violation at address error. To check your RAM for corruption, do the following.
- In your computer’s search bar, type in “Windows memory diagnostic”.
- Run the program.
- Choose the first option which is to restart and check for issues.
- Let it run and wait for the results.
If your RAM is corrupted, you should replace it.
6. Troubleshoot Your Hardware.
Some individuals have had luck in fixing the access violation at address error by resolving issues with their hardware.
- In your computer’s search bar, type in settings, and open it. Or if you are on Windows 10, press down the Windows key + I at the same time.
- Click on the “update and security” section.
- In the left-hand menu, find troubleshoot and click it.
- Run it and follow the on-screen instructions.
Once the troubleshooting has finished, try running your program again to see if the access violation error has been resolved.
7. Run Your Program in Compatibility Mode.
If you are trying to run an older program, it may not be fully compatible with a newer operating system like Windows 10. If you are getting the access violation at address error and it’s pointing directly to the software program, then it may be a compatibility issue.
- Find your program’s shortcut on your desktop and right-click the file.
- Choose the properties option from the menu.
- At the top of the properties menu, find the compatibility tab.
- Choose to “run this program in compatibility mode” and select an older version of Windows, such as Windows 8.1/7.
- Hit apply and okay to save the changes.
- Run the program and see if the issue persists.
You may need to try different compatibility modes depending on how old the program is that you are running.
8. Reinstall the Problematic Software.
It is quite possible that the program you are trying to run has either had portions of it damaged or corrupted from crashes or improper saves or a recent update to it has caused issues. This, in turn, may be the reason behind why the program is now causing access violation errors. Try reinstalling the application to see if the problem persists. To uninstall, do the following.
- In your computer’s search bar, type in settings or hit the Windows key + I at the same time.
- Choose “apps” from the menu.
- Find the application that will not run or launch in the list.
- Click uninstall.
You can also uninstall by going to your computer’s control panel, choosing the programs and features option, and clicking on the uninstall button. If you prefer this method, find the program in the list and hit the uninstall button. Once fully uninstalled, you will need to re-download the program and do a fresh install.
Критическая ошибка, она же более известна как «синий экран смерти», всегда влечёт за собой определённые последствия, так как её возникновение свидетельствует о том, что в работе операционной системы возникли серьёзные неполадки. Каждый пользователь, являющийся оператором компьютера, так или иначе, но сталкивался с проявлением подобной проблемы и знает, что далеко не всегда её решение лежит на «поверхности». Порой для исправления возникшей ситуации приходится прибегать к крайним мерам – это фактическая переустановка операционной системы Windows. Стоит ли применять данный способ в решении рассматриваемой в настоящей статье ошибки, в чём заключаются причины её возникновения. Обо всём об этом вы сможете прочитать ниже.
Исправление ошибки Access violation.
Причины и решения
Такой универсальный вариант (переустановка ОС) уже давно является наиболее рекомендуемым на различных IT-форумах, а также некоторыми «специалистами» воспринимается как «панацея» от любых проблем, что, конечно же, не отвечает действительности. Да, справедливости ради стоит отметить, что полная чистая переустановка Windows практически гарантированно решит имеющиеся программные проблемы, но ни в коем разе не аппаратные. Поэтому не стоит спешить «сносить» операционную систему, для начала следует определить причинно-следственную связь и только после этого принимать подобные кардинальные решения. Итак, рассматриваемая ошибка «Access violation» сигнализирует о том, что какой-либо процесс при обращении к нужному ему типу памяти встречается с трудностями. Например, при запуске игрового программного обеспечения процесс пытается обратиться не к свойственному ему типу памяти, вызывая при этом упомянутую выше ошибку, которая сопровождается текстовым сообщением в виде «Access violation at address № in module «…dll. Write of address…».
Причин возникновения подобной ситуации может быть очень много, что серьёзно усложняет определение причинно-следственной связи, поэтому и применяемые методы носят комплексный характер, а именно:
- Проведите полную проверку операционной системы на наличие вирусной активности. Не прибегайте исключительно к услугам штатного антивируса, а обратите своё внимание на сторонние утилиты, к примеру, «DoctorWeb Curelt», «Malwarebytes» и «Adwcleaner». Проверьте всё тесно связанное с работой компьютера, включая внешние устройства хранения информации, которые подключались ранее к компьютеру, так как не исключено, что основная «зараза» засела именно там.
- Проверьте операционную систему на целостность компонентов, для этого:
Процесс сканирования и внесение правок может быть продолжительным, но прерывать функционирование утилиты не рекомендуется. Дополнительно после завершения работы «sfc/scannow» можно обратиться к помощи команды «dism.exe /online /cleanup-image / restorehealth», инициировать работу, которой можно с помощью той же командной строки.
- Также будет не лишним проверить используемые жёсткие диски и/или твердотельные накопители и наличие битых секторов, ошибки. Для этого подойдёт хотя бы штатная утилита «CHKDSK».
Вышеизложенные рекомендации носят обобщённый характер, так как их применение обосновано не только при возникновении каких-либо проблем в работе операционной системы, но и как профилактические меры по поддержанию качества функционирования Windows. Если ошибка не нашла своего решения и продолжается «терзать» пользователя, то следует прибегнуть к более точечным проверкам, которые заключаются в следующем:
- «Проверка реестра»:
Также будет не лишним прибегнуть к функционалу программы «CCleaner» для проверки реестра на ошибки. Основную проблему это может не решить, но добиться улучшения общего состояния операционной системы вполне реально.
- «Проверка корректности используемого драйверного обеспечения». Откройте «Диспетчер устройств» и удостоверьтесь, что все компоненты полностью работоспособны и среди них нет неизвестного устройства, которое было бы помечено жёлтым треугольником с восклицательным знаком внутри. Дополнительно можно обратиться к специализированному софту и проверить актуальность всех используемых драйверов.
- «Проверка качества работы программного обеспечения». Если рассматриваемая проблема проявилась при открытии какой-либо программы или игры, то попробуйте полностью удалить их и установить заново, но удостоверившись в том, что возможности вашего компьютера, а также версия операционной системы соответствует техническим требованиям продукта. Если игра была получена не совсем «честным/законным» путём, то попробуйте скачать другой репак или сменить основной источник. Если вы уверены в том, что вирусного программного обеспечения нет и проблема проявляется в отдельно взятом программном обеспечении при любых манипуляциях с ним, то можно попробовать внести данное ПО в список исключения DEP, для этого:
Перезагрузите компьютер и проверьте качество работы Windows и работоспособность нужной вам программы/игры.
Заключение
К сожалению, как видно из всего представленного выше, в рассматриваемой ошибке нет каких-то конкретных причин возникновения. «Access violation», как и её собратья, является лишь следствием каких-либо сбойных моментов в работе Windows, поэтому и все приведённые рекомендации направлены на восстановление штатной работы OS. Всё сказанное в начале про переустановку Windows таковым и остаётся и в завершении статьи.
Примечание для людей, заходящих сюда из поисковика: эта статья написана для разработчиков программ. Если вы не программист и не пытаетесь исправить ошибку в СВОЕЙ программе, эта статья — не для вас. До свидания. Извините, что потратил ваше время.
Примечание для студентов/новичков, пишущих на 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» и пункты «а»-«б» в конце второго раздела). Но в следующий раз мы пойдём чуть дальше и посмотрим, что ещё можно сделать для отлова таких ситуаций. И, в любом случае, у вас всегда есть возможность переписать код
Читать дальше.
См. также: как читать баг-отчёты.
Примечания:
(*) Очень подробно о памяти для приложений рассказывает Марк Руссинович.
(**) Вот ещё один пример, как один и тот же код может демонстировать широкий диапазон поведений.
Skip to content
Основная проблема с которой сталкиваются пользователи ПК — является «синий экран смерти». Его появление может свидетельствовать о проблемах с исполняемыми системными файлами которые подверглись изменениям или перезаписыванию. Решение возникших сложностей не всегда можно назвать простыми. Одни решаются буквально за пару минут, а у других следует определить корень. Исходя из информации которую нам предоставляет Windows, мы следует процедуре восстановления повреждённых объектов файловой системы. Некоторые ради экономии времени или по незнанию начинают полную переустановку, но мы с Вами попытаемся решить ошибку без данной процедуры.
Причины возникновения и разновидности
Нам хотелось бы выделить основные текстовые и кодовые представления ошибки встречаемые пользователями. В большинстве случаев помогает полная переустановка системы. Данная процедура решит большинство проблем, при перезаписи исполняемых файлов. Замена битых файлов совершенно новыми — один из вариантов решения.
Основной причиной возникновения можно назвать нарушение целостности системы. При рассмотрении ошибки «Access violation» мы взяли за исходные материалы сами исполняемые процессы. При детальном рассмотрении можно обнаружить, что процесс обращается к .dll файлам у которых затёрты заголовоки. В результате мы видим на экране «Access violation at address $ (где символ $ — код процесса) in module«. Определение причины по коду можно сделать из панели администрирования Windows.
Дополнительной серьезной причиной могут служить битые секторы в которые при дефрагментации были записаны корневые файлы. Обычно это драйвера или .dll-ки папки Виндовс.
Способы решение ошибки
Нам потребуется заняться восстановлением целостности системы. Хорошо поможет специальная команда встроенная в операционную систему. Для ее вызова, следуем инструкции:
- Нажимаем WIN+R для открытия диалогового окна ввода команды.
- Пишем команду cmd и нажимаем ОК.
- На экране отобразится терминал работы с системой:
- Вводим команду «sfc/scannow«.
- Нам предложат перезагрузить систему для исправления ошибок.
- Перезапускаемся и ничего не нажимаем. Начнется автоматическая проверка целостности файлов.
- После запуска, вновь заходим в терминал и вводим команду «chkdsk C: /f /r«. Она проверит жесткие диски на битые секторы и заблокирует их, предварительно перенеся файлы в безопасное место.
- Ошибка Access violation at address должна исчезнуть.
Второй способ заключается в стандартных действиях которые каждый пользователь должен выполнять ежедневно.
- Займитесь проверкой и обновлением системы до последней версии.
- Обновите драйвера видеокарт, если Access violation появляется при запуске игры.
- Исполняемые файлы VC++ должны быть в актуальном состоянии. Скачать можно с официального сайта Microsoft.
- Произведите дефрагментацию диска С. Это поможет перенести данные в рабочие секторы жесткого диска (если у вас SSD, то пропускаем шаг).
( 1 оценка, среднее 2 из 5 )
The accepted answer does not tell the entire story.
Yes, whenever you see zeros, a NULL
pointer is involved. That is because NULL
is by definition zero. So calling zero NULL
may not be saying much.
What is interesting about the message you get is the fact that NULL
is mentioned twice. In fact, the message you report looks a little bit like the messages Windows-brand operating systems show the user.
The message says the address NULL
tried to read NULL
. So what does that mean? Specifically, how does an address read itself?
We typically think of the instructions at an address reading and writing from memory at certain addresses. Knowing that allows us to parse the error message. The message is trying to articulate that the instruction at address NULL
tried to read NULL
.
Of course, there is no instruction at address NULL
, that is why we think of NULL
as special in our code. But every instruction can be thought of as commencing with the attempt to read itself. If the CPUs EIP
register is at address NULL
, then the CPU will attempt to read the opcode for an instruction from address 0x00000000 (NULL
). This attempt to read NULL
will fail, and generate the message you have received.
In the debugger, notice that EIP
equals 0x00000000 when you receive this message. This confirms the description I have given you.
The question then becomes, «why does my program attempt to execute the NULL
address.» There are three possibilities which spring to mind:
- You have attempt to make a function call via a function pointer which you have declared, assigned to
NULL
, never initialized otherwise, and are dereferencing. - Similarly, you may be calling an «abstract» C++ method which has a
NULL
entry in the object’s vtable. These are created in your code with the syntaxvirtual function_name()=0
. - In your code, a stack buffer has been overflowed while writing zeros. The zeros have been written beyond the end of the stack buffer, over the preserved return address. When the function later executes its
ret
instruction, the value 0x00000000 (NULL
) is loaded from the overwritten memory spot. This type of error, stack overflow, is the eponym of our forum.
Since you mention that you are calling a third-party library, I will point out that it may be a situation of the library expecting you to provide a non-NULL
function pointer as input to some API. These are sometimes known as «call back» functions.
You will have to use the debugger to narrow down the cause of your problem further, but the above possiblities should help you solve the riddle.
Contents
- What Does Access Violation Mean on Windows 10?
- How to Resolve the Exception Access Violation Error on Windows 10
- Perform a Malware Scan
- Add Data Execution Prevention Exception
- Disable User Account Control
- Make Sure the Affected Software Isn’t Set as Read-only
- Run the Problematic Program in Compatibility Mode
- Check Your RAM for Corruption
- Create an options.ini file
- Troubleshoot Your Hardware
- Reinstall the Problematic Software
- Best solutions to the “Access Violation at Address” error on Windows 11
- Conclusion
Some software programs may not launch normally if your computer has corrupted software or memory. Anytime your access is denied, you will usually receive an access violation error, which usually reads, “Exception_Access_Violation.” In most cases, it comes with an error code or address.
Malware infections and faulty hardware may cause the Exception_Access_Violation issue. Improper file settings and compatibility errors may also result in the problem. If you’re looking for ways to fix the Exception_Access_Violation error on Windows 10, this article will help you.
What Does Access Violation Mean on Windows 10?
“Access Violation at Address” errors can happen on every version of Windows, including Windows 10. If you see this message, it means the software you’re trying to run is attempting to access a protected memory address. It appears in the form of a pop-up window that prevents PC users from using particular programs.
The thing is, the Exception Access Violation error almost always occurs in any application. Many users have reported encountering the issue while running JAVA, Visual Studio, and antivirus applications. It even appears while operating certain games such as World of Warships, Overwatch, and Minecraft.
How to Resolve the Exception Access Violation Error on Windows 10
Perform a Malware Scan
If your computer is heavily infected with malware, it can corrupt your memory system and cause this error to appear. You should perform a thorough and detailed security scan if you have noticed suspicious behavior on your computer. Occasionally, the Windows built-in antivirus software may not find anything. So, you might want to try another option such as Auslogics Anti-Malware. This tool can identify a potential malware infection that was ignored by your primary antivirus.
If malware isn’t the problem, we recommend scanning your system using a PC optimization tool such as Auslogics BoostSpeed. BoostSpeed’s cleaning module is designed to clean all types of PC junk. It safely removes temporary system and user files, problematic system files, leftover Windows Update files, temporary Sun Java files, and much more. Some registry anomalies, such as empty keys, do not typically pose any issues until they accumulate over time. They can become extremely complicated, rendering your computer useless. This is why we recommend using the Registry Cleaner in BoostSpeed. Experts consider it one of the safest tools for eliminating all those annoying glitches and crashes once and for all.
Add Data Execution Prevention Exception
It’s possible to add the problematic program to a data execution prevention exception list if there’s no malware on your computer. This will let you run the program regardless of the “Access Violation at Address” error.
- Input “Control Panel” (without the quotes) in your Windows Search bar and launch the app.
- Scroll down and click on System.
- In the left pane, click on Advanced System Settings.
- In the Advanced tab, click on Settings under the Performance section.
- In the Performance Options window, click on the Data Executive Prevention tab.
- Tick the “Turn on DEP for all programs and services except those I select” option, then click on the Add button and find your program’s .exe file.
- Add it to the list, click on Apply, and then on Okay to save the changes.
Try running the problematic program again to see if you still get the Access Violation at Address error.
Disable User Account Control
You are more likely to encounter the Access Violation at Address problem if you are trying to install or run a Java-based application. If this is the case, you can temporarily disable User Account Control to fix the problem.
- In your Windows search bar, enter “Control Panel” (without the quotes) and launch the app.
- Scroll down and click on User Accounts.
- In the right pane, click on Change User Account Control settings.
- Move the slider down to “Never Notify” and click OK.
Try running the affected program again to see if the problem has been resolved. After you run your program, remember to enable your user account settings.
Make Sure the Affected Software Isn’t Set as Read-only
You won’t be able to launch or run a program effectively if it’s in read-only mode. Here’s how to check and fix it:
- Locate the affected program’s shortcut on your desktop and right-click on the file.
- From the menu, select the Properties option.
- Go to the General tab, locate the Attributes section and make sure the read-only option is not checked.
- Click on Apply, then on Ok to save changes.
Run the Problematic Program in Compatibility Mode
The reason you are receiving an Exception Access Violation error message on your PC could be due to compatibility issues. Some older programs that you are trying to run may not be compatible with newer operating systems like Windows 10. Nevertheless, your operating system has a feature called Compatibility Mode that lets you run older applications. If you encounter this problem with an application, you can enable Compatibility mode.
- Locate the affected program’s shortcut on your desktop and right-click on the file.
- From the menu, select the Properties option.
- In the Properties menu, select the Compatibility tab.
- Select the Run this program in compatibility mode checkbox, then select an older windows version from the drop-down menu.
- Click on Apply and OK to save changes.
Run the problematic program again to see if you still get the Access Violation at Address error.
Check Your RAM for Corruption
You may encounter this Access Violation at Address error if you previously had a malware infection that caused damage to parts of your RAM.
You can check your RAM for corruption using the following steps:
- Input “Windows memory diagnostic” (without the quotes) in your Windows Search bar and launch the program.
- Click on the “Restart now and check for problems” option.
- Just let the program run and wait for its results.
You should replace your RAM if it is corrupted.
Create an options.ini file
If Lord of The Rings: Battle for Middle Earth is the program giving the EXCEPTION_ACCESS_VIOLATION error, follow the steps below:
- Use the Win + R shortcut to launch the Run box.
- Input “%appdata%” (without the quotes) and click Enter.
- In the folder, create an options.ini file if it doesn’t exist there.
- Right-click on an empty space in the folder, and choose New > Text Document.
- Paste the following lines into the Text Document:
AudioLOD = Low
HasSeenLogoMovies = yes
IdealStaticGameLOD = VeryLow
Resolution = 800 600
StaticGameLOD = VeryLow
TimesInGame = 1
- Now, select File > Save as.
- Choose All Files and enter the options.ini in the File name section.
- Select the AppData > My Battle for Middle Earth Files folder as the saving location and click Save.
Troubleshoot Your Hardware
Many Windows users have had success in fixing the Access Violation at Address error by resolving their hardware issues. Simply follow the steps below:
- Use the Win + I shortcut to launch the Settings app.
- Click on Update & Security.
- In the left pane, click on Troubleshoot.
- Follow the on-screen instructions to run the troubleshooter.
- Wait for the troubleshooting process to be completed.
Run the problematic program again to see if you still get the Access Violation at Address error.
Reinstall the Problematic Software
If you get the Access Violation at Address error when running a certain application, try reinstalling the affected program. There is a good chance that parts of the app you are trying to run have been damaged from crashes or improper saves. Perhaps, a buggy update has caused issues.
To remove the affected program, follow these steps:
- Use the Win + I shortcut to launch the Settings app.
- Click on Apps.
- Locate the problematic application from the list and click on Uninstall.
- Follow the usual procedure for installing the affected program.
Best solutions to the “Access Violation at Address” error on Windows 11
One of the ways of getting rid of errors and glitches on Windows is updating to the latest version of the OS available. Typically, operating system upgrades happen automatically. However, if you haven’t received the latest upgrade, follow these steps:
- Go to Start.
- Select Settings.
- Navigate to Update & Security.
- Select Windows Update
- Go to Check for updates.
If an update is available, it will be automatically installed.
Windows 11 comes with several notable upgrades including new widgets, system tray upgrades, redesigned settings, multiple desktops — and more. However, while a lot of glitches and errors have been addressed in Windows 11, you may still be running into the Access Violation at Address” error.
Now, if you need to solve the “Access Violation at Address” error on Windows 11, you can go through all the same fixes as listed above. This includes:
- Running a malware scan
- Adding the data execution prevention exception
- Making sure that the affected software isn’t set to “read only”
- Checking your RAM for corruption
- Troubleshooting your hardware
- And, finally, reinstalling the problematic software
If you believe that your system is infected with malware but your default antivirus program hasn’t revealed any issues, consider getting a second opinion and running a scan with Auslogics Anti-Malware. The software is fully compatible with Windows 10 and Windows 11 and has been upgraded to detect even the rarest malicious items on a PC.
If a malware scan hasn’t revealed any issues on your system but you are still running into errors and experiencing a general slowdown of your system, consider using Auslogics BoostSpeed.
The program has been designed for Windows 11 and can efficiently remove junk files and other speed reducing issues from your PC in just a few clicks.
Conclusion
There you have it—nine solutions to fix your “Access Violation at Address” problems on Windows 10. Feel free to use the comment box below to share which method helped you get rid of the error.