Microsoft MVP성태의 닷넷 이야기
오류 유형: 30. x64 환경: .NET + COM 프로젝트 실행 시 오류 - 80040154 [링크 복사], [링크+제목 복사],
조회: 40689
글쓴 사람
정성태 (techsharer at outlook.com)
홈페이지
첨부 파일
 


x64 환경: .NET + COM 프로젝트 실행 시 오류 - 80040154


x86 운영체제와는 달리, x64 환경으로 이전해 오면서 이런 문제도 발생하게 되는군요.

솔루션에 Win32 COM 프로젝트와 .NET 프로젝트를 두고 테스트를 하였습니다. Win32 COM 프로젝트는 기본 구현에서 새로운 ATL Simple Object를 추가한 상태이고, 이를 .NET 프로젝트 측에서 참조한 후, 해당 COM 개체를 생성하려는 데 다음과 같은 오류가 발생하는 경우입니다.

vcpp_cs_mixed_error_1.PNG

"
An unhandled exception of type
'System.Runtime.InteropServices.COMException' occurred in mscorlib.dll

Additional information: Retrieving the COM class factory for component with
CLSID {....} failed due to the following error: 80040154
"

원인은 간단합니다. Win32 VC++ 프로젝트 유형은 빌드 시에 기계어로의 컴파일이 완료되는 반면, 닷넷 프로젝트는 실행 시에 JIT 컴파일러에 의해서 대상 머신에 최적화된 기계어로 변환되기 때문입니다.

감이 오시죠? ^^

Win32 VC++ 프로젝트는 다음과 같이 기본값이 "X86"으로 지정되어 있습니다.

vcpp_cs_mixed_error_2.PNG

닷넷 프로젝트는 여러분들도 잘 아시는 것처럼 "Any CPU"로 지정되어 있습니다.

vcpp_cs_mixed_error_3.PNG

결과적으로, ConsoleApplication1 응용 프로그램은 실행 시에 대상 머신의 환경에 맞게 64비트 응용 프로그램으로 구동되는 반면, 그 내부에서 생성되는 COM DLL은 32비트로 컴파일 되어 있어 로드 시에 오류가 발생하게 되는 것입니다.

그렇다면, 해결 방법은?
어쩔 수 없지요. 어느 한쪽에서 맞춰주는 수밖에는. 닷넷에서 "Any CPU" 값을 "x86"으로 바꿔주거나, COM DLL 프로젝트에서 "X64"로 바꿔주어야 합니다.




[이 토픽에 대해서 여러분들과 의견을 공유하고 싶습니다. 틀리거나 미흡한 부분 또는 의문 사항이 있으시면 언제든 댓글 남겨주십시오.]







[최초 등록일: ]
[최종 수정일: 7/5/2021]

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

비밀번호

댓글 작성자
 



2022-04-06 11시02분
[송예은] 저 창은 어떻게 여신 건가요?? 방법을 알 수 있을까요?
[guest]
2022-04-06 11시10분
@송예은 비주얼 스튜디오에서 해당 프로젝트를 마우스 우클릭해 "속성(Properties)" 메뉴를 선택하면 됩니다.
정성태

... 151  152  153  154  155  156  157  158  159  160  161  162  [163]  164  165  ...
NoWriterDateCnt.TitleFile(s)
967정성태12/27/201028310.NET Framework: 197. .NET 코드 - 단일 Process 실행파일 다운로드1
966정성태12/26/201026262.NET Framework: 196. .NET 코드 - 창 흔드는 효과파일 다운로드1
965정성태12/25/201027761개발 환경 구성: 93. MSBuild를 이용한 닷넷 응용프로그램의 다중 어셈블리 출력 빌드파일 다운로드1
964정성태12/21/2010142932개발 환경 구성: 92. 윈도우 서버 환경에서, 최대 생성 가능한 소켓(socket) 연결 수는 얼마일까? [14]
963정성태12/13/201027787개발 환경 구성: 91. MSBuild를 이용한 닷넷 응용프로그램의 플랫폼(x86/x64)별 빌드 [2]파일 다운로드1
962정성태12/10/201022712오류 유형: 110. GAC 등록 - Failure adding assembly to the cache: Invalid file or assembly name.
961정성태12/10/201099701개발 환경 구성: 90. 닷넷에서 접근해보는 PostgreSQL DB [5]
960정성태12/8/201045005.NET Framework: 195. .NET에서 코어(Core) 관련 CPU 정보 알아내는 방법파일 다운로드1
959정성태12/8/201031831.NET Framework: 194. Facebook 연동 - API Error Description: Invalid OAuth 2.0 Access Token
958정성태12/7/201028788개발 환경 구성: 89. 배치(batch) 파일에서 또 다른 배치 파일을 동기 방식으로 실행 및 반환값 얻기 [2]
957정성태12/6/201031544디버깅 기술: 31. Windbg - Visual Studio 디버그 상태에서 종료해 버리는 응용 프로그램 [3]
953정성태11/28/201036778.NET Framework: 193. 페이스북(Facebook) 계정으로 로그인하는 C# 웹 사이트 제작 [5]
952정성태11/25/201025199.NET Framework: 192. GC의 부하는 상대적인 것! [4]
950정성태11/18/201076586.NET Framework: 191. ClickOnce - 관리자 권한 상승하는 방법 [17]파일 다운로드2
954정성태11/29/201048556    답변글 .NET Framework: 191.1. [답변] 클릭원스 - 요청한 작업을 수행하려면 권한 상승이 필요합니다. (Exception from HRESULT: 0x800702E4) [2]
949정성태11/16/201027115오류 유형: 109. System.ServiceModel.Security.SecurityNegotiationException
948정성태11/16/201035897.NET Framework: 190. 트위터 계정으로 로그인하는 C# 웹 사이트 제작 [7]파일 다운로드1
947정성태11/14/201041618.NET Framework: 189. Mono Cecil로 만들어 보는 .NET Decompiler [1]파일 다운로드1
946정성태11/11/201041444.NET Framework: 188. .NET 64비트 응용 프로그램에서 왜 (2GB) OutOfMemoryException 예외가 발생할까? [1]파일 다운로드1
945정성태11/11/201024959VC++: 44. C++/CLI 컴파일 오류 - error C4368: mixed types are not supported
944정성태11/11/201031419VC++: 43. C++/CLI 컴파일 오류 - error C2872: 'IServiceProvider' : ambiguous symbol could be ...
943정성태11/8/201030524디버깅 기술: 30. windbg ".loadby sos" 명령어 [2]
942정성태11/7/201042104.NET Framework: 187. 실행 시에 메서드 가로채기 - CLR Injection: Runtime Method Replacer 개선 [7]파일 다운로드3
941정성태11/6/201025051.NET Framework: 186. windbg로 확인하는 .NET CLR LCG 메서드(DynamicMethod) [1]파일 다운로드1
940정성태11/6/201025924.NET Framework: 185. windbg로 확인하는 .NET CLR 메서드파일 다운로드1
939정성태10/24/201032917Windows: 51. RDP로 접속한 Windows Server 2008 R2 환경에서 Aero Glass 활성화 [1]
... 151  152  153  154  155  156  157  158  159  160  161  162  [163]  164  165  ...