Microsoft MVP성태의 닷넷 이야기
글쓴 사람
정성태 (techsharer at outlook.com)
홈페이지
첨부 파일
 
(연관된 글이 2개 있습니다.)

Windows Form의 Load 이벤트에서 발생하는 예외가 Visual Studio에서 잡히지 않는 문제

마침 질문해 주신 분이 계셔서. ^^

VS2010의 윈폼의 Load 이벤트에서 예외가 잡혀지지 않습니다.
; https://www.sysnet.pe.kr/3/0/990

사실, 제 경우에도 여러 번 겪은 상황이었는데 지금까지 별다른 의문을 갖어본 적이 없습니다. 그냥 ^^; Load 이벤트에서만 그런 식으로 밖에 처리가 안되나 보다... 했었습니다.

검색을 해보니, 역시 마이크로스프트 측에서도 bug라고 인정하는 글이 나옵니다.

VS do not stop execution on error
; http://social.msdn.microsoft.com/Forums/en-US/vsdebug/thread/27f247e0-b856-45f5-aae7-fb5d96b3bc0f/

그리고, 우회적인 해결책이라면 "I suggest you to switch to x86 system for development."라고 말한 것처럼 x86 윈도우 환경으로 바꾸는 정도입니다. (제 테스트 PC의 x86 환경에서는 실제로 Load 이벤트에서 정상적으로 예외가 잡혔습니다.)




제 경우에 이런 때 어떻게 대응하냐고 물으셨는데요. 개인적으로 2가지 방법을 씁니다.

간단하게는, 코드 상에서 다음과 같이 Load 이벤트의 처음과 끝을 감싸는 try/catch를 만들고 catch에 BP(Breakpoint)를 걸어둡니다.

ex_in_load_event_1.png

그러면, 어떤 예외가 발생했는지와 콜 스택까지 모두 확인할 수 있어서 코드 라인까지 확인할 수 있습니다.

그 외에, 코드를 바꾸지 않는 방법도 있지만 더 복잡합니다. 우선, 디버거로 실행한 후 "Output" 창에 출력된 메시지를 확인합니다. 예를 들어, 위의 코드에서는 다음과 같은 예외가 남아 있습니다.

ex_in_load_event_2.png

'WindowsFormsApplication1.vshost.exe' (Managed (v4.0.30319)): Loaded 'D:\Settings\desktop\load_evt\WindowsFormsApplication1\WindowsFormsApplication1\bin\Debug\WindowsFormsApplication1.exe', Symbols loaded.
A first chance exception of type 'System.ApplicationException' occurred in WindowsFormsApplication1.exe


이렇게 알아낸 "System.ApplicationException"을 다음의 글에 설명한 데로 "Debug" / "Exceptions..." 메뉴(Ctrl+D,E)로 들어가서 "Thrown" 항목에 체크를 해 둡니다.

First-Chance Exception
; https://www.sysnet.pe.kr/2/0/510

이렇게 한 다음, 다시 "F5 디버깅"을 시작하면 Load 이벤트 안에서도 정확하게 그 위치에서 예외가 잡힙니다.




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

[연관 글]






[최초 등록일: ]
[최종 수정일: 6/21/2021]

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

비밀번호

댓글 작성자
 




... [196]  197 
NoWriterDateCnt.TitleFile(s)
39정성태7/17/200324220VS.NET IDE: 5. 원격 제어 3가지 방법
38정성태7/17/200320798.NET Framework: 8. IIS 서버 재설치와 ASP.NET 서비스의 문제점
36정성태7/17/200321449.NET Framework: 7. 시행착오 - WebService 참조 추가 오류
35정성태7/17/200322006.NET Framework: 6. Win2000에서의 .NET COM+ 자동 등록 오류 발생 해결
34정성태7/17/200320658VS.NET IDE: 4. VC++ 원격 디버깅파일 다운로드1
33정성태7/17/200320822VS.NET IDE: 3. Win2000 NAT 서비스
32정성태7/17/200322051COM 개체 관련: 9. _bstr_t, CComBSTR, string 클래스 사용 [1]
31정성태7/17/200319180COM 개체 관련: 8. IDL 구문에서 구조체를 pack 하는 방법
30정성태7/17/200336420VC++: 7. [STL] vector 사용법 및 reference 사용예 [1]파일 다운로드1
28정성태7/17/200320828스크립트: 3. Programming Microsoft Internet Explorer 5 - CHM 파일
29정성태7/17/200320279    답변글 스크립트: 3.1. Programming Microsoft Internet Explorer 5 - 소스코드
27정성태7/17/200319196COM 개체 관련: 7. HTML Control에서 DELETE, 화살표 키 등이 안 먹는 문제
26정성태7/17/200320367COM 개체 관련: 6. WebBrowser 콘트롤에서 프레임을 구하는 소스
25정성태7/17/200317982COM 개체 관련: 5. C++ Attributes - Make COM Programming a Breeze with New Feature in Visual Studio .NET [2]파일 다운로드1
24정성태7/17/200321623.NET Framework: 5. (MHT 변환해서 가져온 글) .NET 의 COM+ 서비스 사용파일 다운로드1
23정성태7/17/200325329.NET Framework: 4. webservice.htc - HTML Script에서도 웹서비스 엑세스 [2]파일 다운로드1
22정성태7/17/200319844.NET Framework: 3. .NET Framework SDK 퀵 스타트 자습서
21정성태7/17/200318894.NET Framework: 2. 김현승님의 "ASP.NET & .NET EnterpriseServices & Remoting 코드 템플릿"
20정성태2/15/200525930VS.NET IDE: 2. Platform SDK 설치
19정성태7/17/200321829.NET Framework: 1. JScript.NET 강좌 사이트[영문]
18정성태7/17/200319265COM 개체 관련: 4. Exchanging Data Over the Internet Using XML [1]파일 다운로드1
17정성태7/17/200327249VC++: 6. Win32 API Hook - 소스는 "공개소스"에있습니다. [2]
16정성태7/17/200319548COM 개체 관련: 3. IE 툴밴드의 위치문제파일 다운로드1
15정성태7/17/200320572VC++: 5. 시행착오 - 클래스 포인터를 void * 로 대입후 delete 하는 경우.
14정성태7/17/200322136VC++: 4. MFC Message 처리 구조
13정성태7/17/200321861VC++: 3. template 활용의 최고 단계!
... [196]  197