부모글 보이기/감추기 AD BLOCK 해제 요청 이 글에는 광고가 많이 들어가 있지 않습니다. adblock을 해제하셔도 글을 읽는데 그다지 부담이 없으니 해제를 부탁드립니다. (연관된 글이 1개 있습니다.) C/C++ 프로젝트의 시작 프로그램으로 .NET Core EXE를 지정하는 경우 닷넷 디버깅이 안 되는 문제 [2020-06-23 업데이트 - 최신 버전의 비주얼 스튜디오에서 "Managed Only (.NET Core)" 디버깅 옵션이 추가되었습니다. C/C++ 프로젝트를 DLL로 만든 경우 디버깅을 하려면 속성 창의 Debugging 옵션을 이용해 다음과 같이 환경 구성을 할 수 있습니다. 그런데 저렇게 외부 EXE 파일 대상으로 .NET Core 프로그램을 지정하는 경우, 예를 들어 다음과 같이, Command: c:\program files\dotnet\dotnet.exe Command Arguments: exec "c:\temp\ConsoleApp1\ConsoleApp1\bin\Debug\netcoreapp2.1\ConsoleApp1.dll" Working Directory: c:\temp\ConsoleApp1\ConsoleApp1\bin\Debug\netcoreapp2.1\ 설정하고 "Managed only" 모드로 F5 디버깅을 실행하면 다음과 같은 오류가 발생합니다. A fatal error has occurred and debugging needs to be terminated. For more details, please see the Microsoft Help and Support web site. HRESULT=0x8000ffff. ErrorCode=0x0. 아마도 .NET Managed Debugger가 대상을 .NET Full Framework으로 인식하고 붙으려는 시도를 하기 때문에 실패하는 것으로 보입니다. 실제로 대상 프로세스를 실행해 두고, "Debug" / "Attach to Process..." 메뉴를 이용해 연결하려는 경우 다음의 5가지 유형이 Managed로 나옵니다. Managed (CoreCLR) Managed (Native compilation) Managed (v3.5, v3.0, v2.0) Managed (v4.6, v4.5, v4.0) Managed Compatibility Mode 이 중에서 CoreCLR 유형으로 연결하면 Managed 코드 디버깅이 가능합니다. 반면 "Managed (v4.6, v4.5, v4.0)"와 같은 걸로 지정하면 디버깅이 안 됩니다. 즉, C/C++ 프로젝트에서의 "Managed only" 모드는 CoreCLR에 대한 배려가 없는 것 같습니다. 어쩔 수 없습니다. ^^ Managed 디버깅을 하고 싶다면 대상 EXE를 만든 프로젝트 기준으로 F5 디버깅을 해야 합니다. [이 글에 대해서 여러분들과 의견을 공유하고 싶습니다. 틀리거나 미흡한 부분 또는 의문 사항이 있으시면 언제든 댓글 남겨주십시오.] [다음 글] Graphics: 34. .NET으로 구현하는 OpenGL (11) - Per-Pixel Lighting[이전 글] 오류 유형: 507. Could not save daemon configuration to C:\ProgramData\Docker\config\daemon.json: Access to the path 'C:\ProgramData\Docker\config' is denied. [연관 글] VS.NET IDE: 147. Visual C++ 프로젝트 - .NET Core EXE를 "Debugger Type"으로 지원하는 기능 추가 [최초 등록일: 12/11/2018] [최종 수정일: 8/20/2021] 이 저작물은 크리에이티브 커먼즈 코리아 저작자표시-비영리-변경금지 2.0 대한민국 라이센스에 따라 이용하실 수 있습니다. by SeongTae Jeong, mailto:techsharer at outlook.com 비밀번호 댓글 작성자 2019-01-31 11시42분 F5 Debug failed with 0x8000ffff when C/C++ project and .NET Core project is mixed.; https://developercommunity.visualstudio.com/t/F5-Debug-failed-with-0x8000ffff-when-CC/1357382 정성태 ... 16 17 [18] 19 20 21 22 23 24 25 26 27 28 29 30 ... NoWriterDateCnt.TitleFile(s) 13492정성태12/19/202310418개발 환경 구성: 699. WSL에 nopCommerce 예제 구성13491정성태12/19/20239418Linux: 63. 리눅스 - 다중 그룹 또는 사용자를 리소스에 권한 부여13490정성태12/19/202310144개발 환경 구성: 698. Golang - GLIBC 의존을 없애는 정적 빌드 방법13489정성태12/19/202310096개발 환경 구성: 697. GoLand에서 ldflags 지정 방법13488정성태12/18/20239549오류 유형: 884. HTTP 500.0 - 명령행에서 실행한 ASP.NET Core 응용 프로그램을 실행하는 방법13487정성태12/16/202310664개발 환경 구성: 696. C# - 리눅스용 AOT 빌드를 docker에서 수행 [1]13486정성태12/15/20239786개발 환경 구성: 695. Nuget config 파일에 값 설정/삭제 방법13485정성태12/15/20239450오류 유형: 883. dotnet build/restore - error : Root element is missing13484정성태12/14/202310196개발 환경 구성: 694. Windows 디렉터리 경로를 WSL의 /mnt 포맷으로 구하는 방법13483정성태12/14/202310462닷넷: 2184. C# - 하나의 resource 파일을 여러 프로그램에서 (AOT 시에도) 사용하는 방법113482정성태12/13/202311707닷넷: 2183. C# - eFriend Expert OCX 예제를 .NET Core/5+ Console App에서 사용하는 방법 [2]113481정성태12/13/202310588개발 환경 구성: 693. msbuild - .NET Core/5+ 프로젝트에서 resgen을 이용한 리소스 파일 생성 방법113480정성태12/12/202312416개발 환경 구성: 692. Windows WSL 2 + Chrome 웹 브라우저 설치13479정성태12/11/202310077개발 환경 구성: 691. WSL 2 (Ubuntu) + nginx 환경 설정13477정성태12/8/202310727닷넷: 2182. C# - .NET 7부터 추가된 Int128, UInt128 [1]113476정성태12/8/202310602닷넷: 2181. C# - .NET 8 JsonStringEnumConverter의 AOT를 위한 개선113475정성태12/7/202310892닷넷: 2180. .NET 8 - 함수 포인터에 대한 Reflection 정보 조회113474정성태12/6/202310406개발 환경 구성: 690. 닷넷 코어/5+ 버전의 ilasm/ildasm 실행 파일 구하는 방법 - 두 번째 이야기13473정성태12/5/202310777닷넷: 2179. C# - 값 형식(Blittable)을 메모리 복사를 이용해 바이트 배열로 직렬화/역직렬화113472정성태12/4/202310164C/C++: 164. Visual C++ - InterlockedCompareExchange128 사용 방법13471정성태12/4/202310700Copilot - To enable GitHub Copilot, authorize this extension using GitHub's device flow13470정성태12/2/202311333닷넷: 2178. C# - .NET 8부터 COM Interop에 대한 자동 소스 코드 생성 도입 [1]113469정성태12/1/202311283닷넷: 2177. C# - (Interop DLL 없이) CoClass를 이용한 COM 개체 생성 방법113468정성태12/1/202310291닷넷: 2176. C# - .NET Core/5+부터 달라진 RCW(Runtime Callable Wrapper) 대응 방식113467정성태11/30/202311006오류 유형: 882. C# - Unhandled exception. System.Runtime.InteropServices.COMException (0x800080A5)113466정성태11/29/202310820닷넷: 2175. C# - DllImport 메서드의 AOT 지원을 위한 LibraryImport 옵션 ... 16 17 [18] 19 20 21 22 23 24 25 26 27 28 29 30 ...