Ты не должен.Нарушение доступа является серьезной проблемой: это неожиданная попытка записи (или чтения) неверного адреса памяти.Как уже пояснил Джон, неуправляемая DLL могла уже повредить память процесса до того, как было поднято нарушение прав доступа.Это может привести к непредсказуемым последствиям в любой части текущего процесса.
Самое безопасное, что нужно сделать - это сообщить пользователю и сразу же выйти.
Еще некоторые подробности: нарушение прав доступа являетсяИсключение ОС (так называемое SEH или структурированное исключение исключение).Это другой тип исключения, чем управляемые исключения CLR из System.Exception
.Вы будете редко видеть исключения SEH в чисто управляемом коде, но если это произойдет, например, в неуправляемом коде, CLR доставит его в управляемый код, где вы также сможете его перехватить 1 .
Однако ловить исключения SEH в большинстве случаев не очень хорошая идея.Дальнейшие подробности разъясняются в статье Обработка исключений из поврежденного состояния в журнале MSDN, где взят следующий текст:
CLR всегда доставлял исключения SEH в управляемый код, используя те же механизмы, что и исключения, создаваемые самой программой.Это не проблема, пока код не пытается обработать исключительные условия, которые он не может разумно обработать.Большинство программ не могут безопасно продолжить выполнение после нарушения прав доступа.К сожалению, модель обработки исключений в CLR всегда поощряла пользователей обнаруживать эти серьезные ошибки, позволяя программам перехватывать любые исключения в верхней части иерархии System.Exception.Но это редко правильная вещь.
1 Это было верно до .NET 3.5.В .NET 4 поведение было изменено.Если вы все еще хотите иметь возможность перехватывать подобные исключения, вам нужно добавить legacyCorruptedStateExceptionsPolicy=true
в app.config.Дальнейшие подробности см. Выше.