Microsoft MVP성태의 닷넷 이야기
글쓴 사람
정성태 (techsharer at outlook.com)
홈페이지
첨부 파일
 
(연관된 글이 1개 있습니다.)
(시리즈 글이 5개 있습니다.)
VS.NET IDE: 161. x64 DLL 프로젝트의 컨트롤이 Visual Studio의 Designer에서 보이지 않는 문제
; https://www.sysnet.pe.kr/2/0/12602

VS.NET IDE: 162.  비주얼 스튜디오 - 상속받은 컨트롤이 디자인 창에서 지원되지 않는 문제
; https://www.sysnet.pe.kr/2/0/12603

VS.NET IDE: 166. Visual Studio 2022 - Windows Forms 프로젝트의 x86 DLL 컨트롤이 Designer에서 오류가 발생하는 문제
; https://www.sysnet.pe.kr/2/0/12683

VS.NET IDE: 168. x64 DLL 프로젝트의 컨트롤이 Visual Studio의 Designer에서 보이지 않는 문제 - 두 번째 이야기
; https://www.sysnet.pe.kr/2/0/12705

VS.NET IDE: 182. Visual Studio - 32비트로만 빌드된 ActiveX와 작업해야 한다면?
; https://www.sysnet.pe.kr/2/0/13322




x64 DLL 프로젝트의 컨트롤이 Visual Studio의 Designer에서 보이지 않는 문제 - 두 번째 이야기

아시다시피, Visual Studio 2019 이하 버전에서는 x64 환경에 대한 디자이너 문제가 있습니다.

x64 DLL 프로젝트의 컨트롤이 Visual Studio의 Designer에서 보이지 않는 문제
; https://www.sysnet.pe.kr/2/0/12602

그리고 지난번 문제도 그렇고요,

wpf x64로 만든 메인 프로그램에서 dll로 된 UserControl 속성이 디자인 타임에 잘 안보이는 문제
; https://www.sysnet.pe.kr/3/0/5526

그런데, 가만 생각해 보니 이에 대한 다른 해결책이 있긴 합니다. 그러니까, 비주얼 스튜디오 디자인 시에는 아무런 문제가 없도록 그냥 AnyCPU (Prefer 32bit) 옵션을 켜 놓고 작업하다가, 빌드 대상물에 대해서만 그 옵션을 끄면 되는 것입니다.

왜냐하면 결국 문제가 되는 것은, 디자인 타임에서 x86으로 실행되는 devenv.exe와 x64로 빌드된 DLL의 플랫폼 충돌이 원인이기 때문입니다.

그래서 해결책이 아주 간단합니다. 이를 위해 해줘야 할 것은, 단지 "Build Events"의 "Post-Build Event"에 corflags.exe(참고: 사용예)를 이용해 "Prefer 32bit" 옵션을 빼도록 실행합니다.

"C:\Program Files (x86)\Microsoft SDKs\Windows\v10.0A\bin\NETFX 4.8 Tools\CorFlags.exe" /32BITPREF- $(TargetPath)

경로가 좀 어지러우니, corflags.exe를 현재 프로젝트에 복사해 추가한 다음 아래와 같이 설정해도 무방합니다.

"$(ProjectDir)CorFlags.exe" /32BITPREF- $(TargetPath)

혹은, csproj 자체를 편집해도 되고!

...[생략]...

<PropertyGroup>
    <PostBuildEvent>"$(ProjectDir)CorFlags.exe" /32BITPREF- $(TargetPath)</PostBuildEvent>
</PropertyGroup>

...[생략]...

끝입니다. 저렇게 설정해 주면 이제 디자이너는 AnyCPU로 설정된 DLL을 로드하므로 문제가 없고, 빌드 결과물은 x64로 실행될 것이므로 또한 문제가 없습니다. 실제로, 이렇게 한 후 디버깅으로 실행해도 Visual Studio는 정상적으로 BP까지 걸어가며 동작하는 데 아무런 문제가 없었습니다.




그리고 이 방법은 Visual Studio 2022 이후 x86 환경에 대한 디자이너 문제를 해결하는데 적용할 수도 있을 것입니다.

Visual Studio 2022 - Windows Forms 프로젝트의 x86 DLL 컨트롤이 Designer에서 오류가 발생하는 문제
; https://www.sysnet.pe.kr/2/0/12683




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

[연관 글]






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

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

비밀번호

댓글 작성자
 




... [31]  32  33  34  35  36  37  38  39  40  41  42  43  44  45  ...
NoWriterDateCnt.TitleFile(s)
13258정성태2/13/202317583오류 유형: 846. .NET Framework 4.8 Developer Pack 설치 실패 - 0x81f40001
13257정성태2/13/202317154.NET Framework: 2094. C# - Job에 Process 포함하는 방법 [2]파일 다운로드1
13256정성태2/10/202315244개발 환경 구성: 665. WSL 2의 네트워크 통신 방법 - 두 번째 이야기
13255정성태2/10/202317831오류 유형: 845. gihub - windows2022 이미지에서 .NET Framework 4.5.2 미만의 프로젝트에 대한 빌드 오류
13254정성태2/10/202316869Windows: 223. (WMI 쿼리를 위한) PowerShell 문자열 escape 처리
13253정성태2/9/202316474Windows: 222. C# - 다른 윈도우 프로그램이 실행되었음을 인식하는 방법파일 다운로드1
13252정성태2/9/202314421오류 유형: 844. ssh로 명령어 수행 시 멈춤 현상
13251정성태2/8/202316050스크립트: 44. 파이썬의 3가지 스레드 ID
13250정성태2/8/202317045오류 유형: 843. System.InvalidOperationException - Unable to configure HTTPS endpoint
13249정성태2/7/202319325오류 유형: 842. 리눅스 - You must wait longer to change your password
13248정성태2/7/202313594오류 유형: 841. 리눅스 - [사용자 계정] is not in the sudoers file. This incident will be reported.
13247정성태2/7/202317076VS.NET IDE: 180. Visual Studio - 닷넷 소스 코드 디버깅 중 "Decompile source code"가 동작하는 않는 문제
13246정성태2/6/202317047개발 환경 구성: 664. Hyper-V에 설치한 리눅스 VM의 VHD 크기 늘리는 방법 - 두 번째 이야기
13245정성태2/6/202316135.NET Framework: 2093. C# - PKCS#8 PEM 파일을 이용한 RSA 개인키/공개키 설정 방법파일 다운로드1
13244정성태2/5/202316766VS.NET IDE: 179. Visual Studio - External Tools에 Shell 내장 명령어 등록
13243정성태2/5/202316846디버깅 기술: 190. windbg - Win32 API 호출 시점에 BP 거는 방법 [1]
13242정성태2/4/202315412디버깅 기술: 189. ASP.NET Web Application (.NET Framework) 프로젝트의 숨겨진 예외 - System.UnauthorizedAccessException
13241정성태2/3/202313528디버깅 기술: 188. ASP.NET Web Application (.NET Framework) 프로젝트의 숨겨진 예외 - System.IO.FileNotFoundException
13240정성태2/1/202315971디버깅 기술: 187. ASP.NET Web Application (.NET Framework) 프로젝트의 숨겨진 예외 - System.Web.HttpException
13239정성태2/1/202313200디버깅 기술: 186. C# - CacheDependency의 숨겨진 예외 - System.Web.HttpException
13238정성태1/31/202319841.NET Framework: 2092. IIS 웹 사이트를 TLS 1.2 또는 TLS 1.3 프로토콜로만 운영하는 방법
13237정성태1/30/202317780.NET Framework: 2091. C# - 웹 사이트가 어떤 버전의 TLS/SSL을 지원하는지 확인하는 방법
13236정성태1/29/202317322개발 환경 구성: 663. openssl을 이용해 인트라넷 IIS 사이트의 SSL 인증서 생성
13235정성태1/29/202316896개발 환경 구성: 662. openssl - 윈도우 환경의 명령행에서 SAN 적용하는 방법
13234정성태1/28/202319877개발 환경 구성: 661. dnSpy를 이용해 소스 코드가 없는 .NET 어셈블리의 코드를 변경하는 방법 [1]
13233정성태1/28/202319920오류 유형: 840. C# - WebClient로 https 호출 시 "The request was aborted: Could not create SSL/TLS secure channel" 예외 발생
... [31]  32  33  34  35  36  37  38  39  40  41  42  43  44  45  ...