다음을 통해 공유


System.AccessViolationException 클래스

이 문서는 이 API에 대한 참조 설명서를 보충하는 추가 설명을 제공합니다.

코드가 할당되지 않았거나 액세스 권한이 없는 메모리를 읽거나 쓰려고 할 때 관리되지 않거나 안전하지 않은 코드에서 액세스 위반이 발생합니다. 포인터에 잘못된 값이 있기 때문에 일반적으로 발생합니다. 잘못된 포인터를 통한 모든 읽기 또는 쓰기가 액세스 위반으로 이어지는 것은 아니므로 액세스 위반은 일반적으로 잘못된 포인터를 통해 여러 읽기 또는 쓰기가 발생했으며 메모리가 손상되었을 수 있음을 나타냅니다. 따라서 액세스 위반은 거의 항상 심각한 프로그래밍 오류를 나타냅니다. 이러한 AccessViolationException 심각한 오류를 명확하게 식별합니다.

완전히 확인 가능한 관리 코드로 구성된 프로그램에서는 모든 참조가 유효하거나 null이며 액세스 위반은 불가능합니다. 확인 가능한 코드에서 null 참조를 참조하려는 모든 작업은 NullReferenceException 예외를 발생시킵니다. AccessViolationException 확인 가능한 관리 코드가 관리되지 않는 코드 또는 안전하지 않은 관리 코드와 상호 작용하는 경우에만 발생합니다.

AccessViolationException 예외 문제 해결

AccessViolationException 안전하지 않은 관리 코드 또는 확인 가능한 관리 코드가 관리되지 않는 코드와 상호 작용하는 경우에만 예외가 발생할 수 있습니다.

두 경우 모두 AccessViolationException 예외의 원인을 식별하고 수정하는 방법은 다음과 같습니다.

  • 액세스하려는 메모리가 할당되었는지 확인합니다. AccessViolationException 예외는 보호된 메모리에 액세스하려는 시도에서 항상 발생합니다. 즉, 할당되지 않았거나 프로세스가 소유하지 않은 메모리에 접근할 때 발생합니다.

    자동 메모리 관리는 .NET 런타임에서 제공하는 서비스 중 하나입니다. 관리 코드가 관리되지 않는 코드와 동일한 기능을 제공하는 경우 관리 코드로 이동하여 이 기능을 활용하는 것이 좋습니다. 자세한 내용은 자동 메모리 관리를 참조하세요.

  • 액세스하려는 메모리가 손상되지 않았는지 확인합니다. 잘못된 포인터를 통해 여러 읽기 또는 쓰기 작업이 발생한 경우 메모리가 손상되었을 수 있습니다. 일반적으로 미리 정의된 버퍼 외부의 주소를 읽거나 쓸 때 발생합니다.

AccessViolationException 및 try/catch 블록

AccessViolationException .NET 런타임에서 던져진 예외는, 런타임에 의해 예약된 메모리 외부에서 발생하는 경우, 구조적 예외 처리기의 catch 문에서 처리되지 않습니다.

.NET Framework만: 이러한 AccessViolationException 예외를 처리하려면, 예외가 발생되는 메서드에 HandleProcessCorruptedStateExceptionsAttribute 특성을 적용합니다. 이 변경은 사용자 코드에서 throw된 예외에 AccessViolationException 영향을 주지 않으며, 이러한 예외는 catch 문으로 계속해서 catch될 수 있습니다.

주의

HandleProcessCorruptedStateExceptions 특성은 현재 .NET 버전에서 사용되지 않습니다. 손상된 프로세스 상태-예외에서 복구는 지원되지 않으며 특성이 있는 경우 무시됩니다.