AccessViolationException 클래스

정의

보호된 메모리를 읽거나 쓰려고 할 때 throw되는 예외입니다.

public ref class AccessViolationException : SystemException
public class AccessViolationException : SystemException
[System.Runtime.InteropServices.ComVisible(true)]
[System.Serializable]
public class AccessViolationException : SystemException
type AccessViolationException = class
    inherit SystemException
[<System.Runtime.InteropServices.ComVisible(true)>]
[<System.Serializable>]
type AccessViolationException = class
    inherit SystemException
Public Class AccessViolationException
Inherits SystemException
상속
AccessViolationException
특성

설명

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

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

AccessViolationException 예외 문제 해결

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

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

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

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

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

AccessViolationException 및 try/catch 블록

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

Caution

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

생성자

Name Description
AccessViolationException()

오류를 설명하는 시스템 제공 메시지를 사용하여 AccessViolationException 클래스의 새 인스턴스를 초기화합니다.

AccessViolationException(SerializationInfo, StreamingContext)
사용되지 않음.

직렬화된 데이터를 사용하여 클래스의 새 인스턴스를 AccessViolationException 초기화합니다.

AccessViolationException(String, Exception)

지정된 오류 메시지와 이 예외의 AccessViolationException 원인인 내부 예외에 대한 참조를 사용하여 클래스의 새 인스턴스를 초기화합니다.

AccessViolationException(String)

오류를 설명하는 지정된 메시지를 사용하여 AccessViolationException 클래스의 새 인스턴스를 초기화합니다.

속성

Name Description
Data

예외에 대한 추가 사용자 정의 정보를 제공하는 키/값 쌍의 컬렉션을 가져옵니다.

(다음에서 상속됨 Exception)
HelpLink

이 예외와 연결된 도움말 파일에 대한 링크를 가져오거나 설정합니다.

(다음에서 상속됨 Exception)
HResult

특정 예외에 할당된 코딩된 숫자 값인 HRESULT를 가져오거나 설정합니다.

(다음에서 상속됨 Exception)
InnerException

현재 예외를 Exception 발생시킨 인스턴스를 가져옵니다.

(다음에서 상속됨 Exception)
Message

현재 예외를 설명하는 메시지를 가져옵니다.

(다음에서 상속됨 Exception)
Source

오류를 발생시키는 애플리케이션 또는 개체의 이름을 가져오거나 설정합니다.

(다음에서 상속됨 Exception)
StackTrace

호출 스택에서 직접 실행 프레임의 문자열 표현을 가져옵니다.

(다음에서 상속됨 Exception)
TargetSite

현재 예외를 throw하는 메서드를 가져옵니다.

(다음에서 상속됨 Exception)

메서드

Name Description
Equals(Object)

지정된 개체가 현재 개체와 같은지 여부를 확인합니다.

(다음에서 상속됨 Object)
GetBaseException()

파생 클래스에서 재정의되는 경우 하나 이상의 후속 예외의 근본 원인인 값을 반환 Exception 합니다.

(다음에서 상속됨 Exception)
GetHashCode()

기본 해시 함수로 사용됩니다.

(다음에서 상속됨 Object)
GetObjectData(SerializationInfo, StreamingContext)
사용되지 않음.

파생 클래스에서 재정의되는 경우 예외에 SerializationInfo 대한 정보를 사용하여 설정합니다.

(다음에서 상속됨 Exception)
GetType()

현재 인스턴스의 런타임 형식을 가져옵니다.

(다음에서 상속됨 Exception)
MemberwiseClone()

현재 Object단순 복사본을 만듭니다.

(다음에서 상속됨 Object)
ToString()

현재 예외의 문자열 표현을 만들고 반환합니다.

(다음에서 상속됨 Exception)

이벤트

Name Description
SerializeObjectState
사용되지 않음.

예외에 대한 직렬화된 데이터를 포함하는 예외 상태 개체를 만들기 위해 예외가 serialize될 때 발생합니다.

(다음에서 상속됨 Exception)

적용 대상

추가 정보