Microsoft MVP성태의 닷넷 이야기
.NET Framework: 20. System.AccessViolationException 예외가 발생한 한 예. [링크 복사], [링크+제목 복사],
조회: 26430
글쓴 사람
정성태 (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)
11249정성태7/12/201718608오류 유형: 410. LoadLibrary("[...].dll") failed - The specified procedure could not be found.
11248정성태7/12/201725097오류 유형: 409. pip install pefile - 'cp949' codec can't decode byte 0xe2 in position 208687: illegal multibyte sequence
11247정성태7/12/201719438오류 유형: 408. SqlConnection 객체 생성 시 무한 대기 문제파일 다운로드1
11246정성태7/11/201718187VS.NET IDE: 118. Visual Studio - 다중 폴더에 포함된 파일들에 대한 "Copy to Output Directory"를 한 번에 설정하는 방법
11245정성태7/10/201723784개발 환경 구성: 321. Visual Studio Emulator for Android 소개 [2]
11244정성태7/10/201723350오류 유형: 407. Visual Studio에서 ASP.NET Core 실행할 때 dotnet.exe 프로세스의 -532462766 오류 발생 [1]
11243정성태7/10/201720043.NET Framework: 666. dotnet.exe - 윈도우 운영체제에서의 .NET Core 버전 찾기 규칙
11242정성태7/8/201720291제니퍼 .NET: 27. 제니퍼 닷넷 적용 사례 (7) - 노후된 스토리지 장비로 인한 웹 서비스 Hang (멈춤) 현상
11241정성태7/8/201719033오류 유형: 406. Xamarin 빌드 에러 XA5209, APT0000
11240정성태7/7/201721964.NET Framework: 665. ClickOnce를 웹 브라우저를 이용하지 않고 쿼리 문자열을 전달하면서 실행하는 방법 [3]파일 다운로드1
11239정성태7/6/201723476.NET Framework: 664. Protocol Handler - 웹 브라우저에서 데스크톱 응용 프로그램을 실행하는 방법 [5]파일 다운로드1
11238정성태7/6/201720991오류 유형: 405. NT 서비스 시작 시 "Error 1067: The process terminated unexpectedly." 오류 발생 [2]
11237정성태7/5/201722620.NET Framework: 663. C# - PDB 파일 경로를 PE 파일로부터 얻는 방법파일 다운로드1
11236정성태7/4/201725896.NET Framework: 662. C# - VHD/VHDX 가상 디스크를 마운트하지 않고 파일을 복사하는 방법파일 다운로드1
11235정성태6/29/201720069Math: 20. Matlab/Octave로 Gram-Schmidt 정규 직교 집합 구하는 방법
11234정성태6/29/201717375오류 유형: 404. SharePoint 2013 설치 과정에서 "The username is invalid The account must be a valid domain account" 오류 발생
11233정성태6/28/201717289오류 유형: 403. SharePoint Server 2013을 Windows Server 2016에 설치할 때 .NET 4.5 설치 오류 발생
11232정성태6/28/201718250Windows: 144. Windows Server 2016에 Windows Identity Extensions을 설치하는 방법
11231정성태6/28/201718878디버깅 기술: 86. windbg의 mscordacwks DLL 로드 문제 - 세 번째 이야기 [1]
11230정성태6/28/201718053제니퍼 .NET: 26. 제니퍼 닷넷 적용 사례 (6) - 잦은 Recycle 문제
11229정성태6/27/201719300오류 유형: 402. Windows Server Backup 관리 콘솔이 없어진 경우
11228정성태6/26/201716755개발 환경 구성: 320. Visual Basic .NET 프로젝트에서 내장 Manifest 자원을 EXE 파일로부터 제거하는 방법파일 다운로드1
11227정성태6/19/201724549개발 환경 구성: 319. windbg에서 python 스크립트 실행하는 방법 - pykd [6]
11226정성태6/19/201716342오류 유형: 401. Microsoft Edge를 실행했는데 입력 반응이 없는 경우
11225정성태6/19/201715700오류 유형: 400. Outlook - The required file ExSec32.dll cannot be found in your path. Install Microsoft Outlook again.
11224정성태6/13/201718195.NET Framework: 661. Json.NET의 DeserializeObject 수행 시 속성 이름을 동적으로 바꾸는 방법파일 다운로드1
... 106  [107]  108  109  110  111  112  113  114  115  116  117  118  119  120  ...