Microsoft MVP성태의 닷넷 이야기
.NET Framework: 20. System.AccessViolationException 예외가 발생한 한 예. [링크 복사], [링크+제목 복사],
조회: 30892
글쓴 사람
정성태 (techsharer at outlook.com)
홈페이지
첨부 파일
 

좀 더 정확히는, 아래와 같은 오류가 발생했습니다.

System.AccessViolationException: attempted to read or write protected memory. This is often an indication that other memory has been corrupted.
 at Microsoft.Office.Interop.InfoPath.SemiTrust._Application2.get_Name()
 at InfoMHost.MyHost.LoadTarget( Object pApp, Object pDoc, String infoXMLText ) in ...... line XX

PIA 어셈블리를 통해서 실제 COM 개체의 메서드/프로퍼티를 호출하는 데 위와 같은 오류가 발생한 것입니다.

직접적인 원인은, PIA 어셈블리에서 구현된 타입의 Method 순서와 실제 COM 개체의 IDL 파일에 정의된 순 가상 함수의 순서가 일치하지 않아서 발생한 것이였습니다.

"Attempted to read or write protected memory" 라고 하는 것은, 즉 PIA 를 통해서 vtable 의 3번째에 있는 함수를 호출했으나, 실제 COM 개체에서는 ( 예를 들어 ) 5번째에 있는 함수 호출을 발생시키다 보니 입력인자/반환인자가 일치하지 않아서 잘못된 메모리 접근을 하게 되어서 그런 듯 싶습니다.

즉, 위와 같은 경우에서만 발생하는 것이 아니고 그 외의 모든 "잘못된 메모리 접근" 에 대해서 발생할 수 있는 문제이므로 버그를 잡는 것이 상당히 어려운 경우라고 할 수 있겠습니다.

이번에는 그나마 좀 쉽게 해결했지만 ^^; 개인적으로 다시는 보고 싶지 않은 예외입니다.








[최초 등록일: ]
[최종 수정일: 1/19/2005]

Creative Commons License
이 저작물은 크리에이티브 커먼즈 코리아 저작자표시-비영리-변경금지 2.0 대한민국 라이센스에 따라 이용하실 수 있습니다.
by SeongTae Jeong, mailto:techsharer at outlook.com

비밀번호

댓글 작성자
 




... 106  107  108  109  110  111  [112]  113  114  115  116  117  118  119  120  ...
NoWriterDateCnt.TitleFile(s)
11216정성태6/1/201721244오류 유형: 396. Activation context generation failed
11215정성태6/1/201724116오류 유형: 395. 관리 콘솔을 실행하면 "This app has been blocked for your protection" 오류 발생 [1]
11214정성태6/1/201720955오류 유형: 394. MSDTC 서비스 시작 시 -1073737712(0xC0001010) 오류와 함께 종료되는 문제 [1]
11213정성태5/26/201727110오류 유형: 393. TFS - The underlying connection was closed: Could not establish trust relationship for the SSL/TLS secure channel.
11212정성태5/26/201726486오류 유형: 392. Windows Server 2016에 KB4019472 업데이트가 실패하는 경우
11211정성태5/26/201724873오류 유형: 391. BeginInvoke에 전달한 람다 함수에 CS1660 에러가 발생하는 경우
11210정성태5/25/201725004기타: 65. ActiveX 없는 전자 메일에 사용된 "개인정보 보호를 위해 암호화된 보안메일"의 암호화 방법
11209정성태5/25/201774115Windows: 143. Windows 10의 Recovery 파티션을 삭제 및 새로 생성하는 방법 [16]
11208정성태5/25/201731004오류 유형: 390. diskpart의 set id 명령어에서 "The specified type is not in the correct format." 오류 발생
11207정성태5/24/201733011Windows: 142. Windows 10의 복구 콘솔로 부팅하는 방법
11206정성태5/24/201725888오류 유형: 389. DISM.exe - The specified image in the specified wim is already mounted for read/write access.
11205정성태5/24/201725200.NET Framework: 658. C#의 tail call 구현은? [1]
11204정성태5/22/201734710개발 환경 구성: 316. 간단하게 살펴보는 Docker for Windows [7]
11203정성태5/19/201721938오류 유형: 388. docker - Host does not exist: "default"
11202정성태5/19/201722935오류 유형: 387. WPF - There is no registered CultureInfo with the IetfLanguageTag 'ug'.
11201정성태5/16/201727538오류 유형: 386. WPF - .NET 3.5 이하에서 TextBox에 한글 입력 시 TextChanged 이벤트의 비정상 종료 문제 [1]파일 다운로드1
11200정성태5/16/201724083오류 유형: 385. WPF - 폰트가 없어 System.IO.FileNotFoundException 예외가 발생하는 경우
11199정성태5/16/201724097.NET Framework: 657. CultureInfo.GetCultures가 반환하는 값
11198정성태5/10/201727388.NET Framework: 656. Windows Forms의 오류(Exception) 처리 방법에 대한 차이점 설명
11197정성태5/8/201722469개발 환경 구성: 315. VHD 파일의 최소 크기파일 다운로드1
11196정성태5/4/201724191오류 유형: 384. Msvm_ImageManagementService WMI 객체를 사용할 때 오류 상황 정리 [1]
11195정성태5/3/201725505.NET Framework: 655. .NET Framework 4.7 릴리스
11194정성태5/3/201726226오류 유형: 383. net use 명령어로 네트워크 드라이브 연결 시 "System error 67 has occurred." 오류 발생
11193정성태5/3/201723993Windows: 141. 설치된 Windows로부터 설치 이미지를 만드는 방법
11192정성태5/2/201726262Windows: 140. unattended.xml/autounattend.xml 파일을 마련하는 방법
11191정성태5/2/201727073Windows: 139. Dell Venue 8 Pro 태블릿에 USB를 이용한 윈도우 운영체제 설치 방법
... 106  107  108  109  110  111  [112]  113  114  115  116  117  118  119  120  ...