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

WPF - .NET 3.5 이하에서 TextBox에 한글 입력 시 TextChanged 이벤트의 비정상 종료 문제

다음과 같은 질문이 있군요.

WPF .net 3.5에서 TextBox 한글 문제
; https://www.sysnet.pe.kr/3/0/4831

위의 문제에 대한 재현은 간단합니다. 기본 생성된 WPF 프로젝트의 MainWindow.xaml에 다음과 같이 TextBox를 하나 얹고,

<TextBox Text="TextBox" TextChanged="TextBox_TextChanged"/>

TextBox_TextChanged 이벤트에 MessageBox를 띄우게 코딩한 후,

private void TextBox_TextChanged(object sender, TextChangedEventArgs e)
{
    MessageBox.Show("TEST");
}

실행 시에 TextBox에 한글을 입력하게 되면 다음과 같은 예외가 발생하거나,
System.InvalidOperationException occurred
  HResult=0x80131509
  Message=There is no registered CultureInfo with the IetfLanguageTag 'ug'.
  Source=<Cannot evaluate the exception source>
  StackTrace:
<Cannot evaluate the exception stack trace>

Inner Exception 1:
ArgumentException: Culture name 'ug' is not supported.

아니면 다음과 같이 간단한 debug 로그만 남긴 체 응용 프로그램이 비정상 종료해 버립니다.

The program '[8296] WpfApp1.exe' has exited with code -1073740940 (0xc0000374).
The program '[8296] WpfApp1.exe: Program Trace' has exited with code 0 (0x0).

사실, "There is no registered CultureInfo with the IetfLanguageTag 'ug'." 예외 메시지는 몇몇 환경에서 나타나는 부가적인 메시지일 뿐 설령 그 오류 메시지를 해결한다 해도 결국에는 0xc0000374 (Heap Corruption Exception) 예외를 발생하며 비정상 종료를 해버립니다.

이벤트 로그에도 역시 간단한 메시지만 남게 되어 도대체 이게 무슨 현상인가 싶을 정도입니다. ^^;

Log Name:      Application
Source:        .NET Runtime
Date:          2017-05-17 오전 12:32:44
Event ID:      1023
Task Category: None
Level:         Error
Keywords:      Classic
User:          N/A
Computer:      TESTPC
Description:
.NET Runtime version 2.0.50727.8784 - Unrecoverable system error.

Log Name:      Application
Source:        Windows Error Reporting
Date:          2017-05-17 오전 12:41:35
Event ID:      1001
Task Category: None
Level:         Information
Keywords:      Classic
User:          N/A
Computer:      TESTPC
Description:
Fault bucket , type 0
Event Name: CLR20r3
Response: Not available
Cab Id: 0

Problem signature:
P1: wpfapp1.exe
P2: 1.0.0.0
P3: 591b1c8a
P4: WindowsBase
P5: 3.0.0.0
P6: 58dbbc47
P7: df
P8: 0
P9: FatalError
P10: 




이 문제를 사실 어떻게 해결해야 할지 모르겠습니다. ^^;

일단, 가장 권장되는 방법은 .NET 4.0으로 올리는 것입니다. 또는 3.5로 개발되었다고 해도 4.0이 설치된 PC에서는 CLR 4.0에서 실행되도록 다음과 같이 app.config을 조정해 주는 것입니다.

<?xml version="1.0" encoding="utf-8"?>
<configuration>
  <startup>
    <supportedRuntime version="v4.0.30319"/>
    <supportedRuntime version="v2.0.50727"/>
  </startup>
</configuration>

그렇다면 3.5 이하의 .NET Framework이 설치된 곳에서는 어떻게 해야 할까요? 이렇게 되면 약간의 꼼수를 써야 하는데요. 제가 생각해 낸 그나마 가장 우아한 방법은 Dispatcher.BeginInvoke를 이용하는 것이었습니다.

private void TextBox_TextChanged(object sender, TextChangedEventArgs e)
{
    this.Dispatcher.BeginInvoke( (Action)(
        () => {
            MessageBox.Show("TEST");
        }), null);
}

혹시 다른 방법을 알고 계신 분은 덧글 부탁드립니다. ^^

(첨부 파일은 이 글의 예제 코드를 포함합니다.)




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

[연관 글]






[최초 등록일: ]
[최종 수정일: 5/17/2017]

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

비밀번호

댓글 작성자
 



2017-05-17 01시24분
[김신철] 항상 많은 정보 알려주셔서 감사합니다~ 큰 도움이 될것같습니다 ^^
[guest]

... 136  137  138  139  [140]  141  142  143  144  145  146  147  148  149  150  ...
NoWriterDateCnt.TitleFile(s)
1554정성태12/26/201335329Windows: 78. 마음에 드는 윈도우 8.1 태블릿 - 델 베뉴 8 프로 5830 [4]
1553정성태12/26/201322350개발 환경 구성: 206. JNBridgePro와 한글 인코딩 문제파일 다운로드1
1552정성태12/25/201327531개발 환경 구성: 205. JNBridgePro를 이용해 C#에서 Java메서드 호출 테스트파일 다운로드1
1551정성태12/24/201322678.NET Framework: 398. tech-days 미니 토요세미나 - 3회 C#편 PPT 자료파일 다운로드1
1550정성태12/13/201325074Windows: 77. Windows 8 - 잠시 사용을 안하는 경우 화면 잠김 상태로 빠지는 문제
1549정성태12/13/201328652VC++: 73. IIS - ISAPI 필터 제작하는 방법 [2]
1548정성태12/10/201321339오류 유형: 198. C# - 제네릭 covariance/contravariance 사용할 때 컴파일 오류가 발생한다면?
1547정성태12/10/201330909.NET Framework: 397. C# - OCX 컨트롤에 구현된 메서드에 배열을 in, out으로 전달하는 방법파일 다운로드2
1546정성태11/28/201324775.NET Framework: 396. C# - 프로퍼티로 정의하면 필드보다 느릴까요? - windbg / ollydbg [3]
1545정성태11/28/201328648.NET Framework: 395. C# - 프로퍼티로 정의하면 필드보다 느릴까요? [3]
1544정성태11/27/201325132개발 환경 구성: 204. Visual Studio Online "Monaco" 서비스와 github 연동
1543정성태11/27/201329880오류 유형: 197. error MSB8008: Specified platform toolset (v120) is not installed or invalid. [1]
1542정성태11/27/201335465오류 유형: 196. The procedure entry point InitializeCriticalSectionEx could not be located in the dynamic link library KERNEL32.dll
1541정성태11/22/201336660.NET Framework: 394. async/await 사용 시 hang 문제가 발생하는 경우 [7]파일 다운로드1
1540정성태11/20/201325110개발 환경 구성: 203. Azure - WEB SITES 서비스 소개 [4]
1539정성태11/19/201329109VS.NET IDE: 83. 형상 관리 서버 운영을 대신해 주는 Visual Studio 온라인 서비스
1538정성태11/19/201329982오류 유형: 195. 웹 사이트의 모든 정적 컨텐츠 요청에 대해 "Internal Server Error" 응답
1537정성태11/19/201321633오류 유형: 194. 윈도우 서버 백업으로 인해 Hyper-V VM들의 상태가 모두 "Backing up..." 상태로 오래 지속되는 문제
1536정성태11/19/201326445오류 유형: 193. 윈도우 서버 백업 - Hyper-V 가상 머신이 백업되지 않는 경우
1535정성태11/18/201326553.NET Framework: 393. Internet Explorer 11에서 ASP.NET 컨트롤의 크기가 달라지는 문제 [1]
1534정성태11/13/201326551.NET Framework: 392. .NET 스레드 콜 스택 덤프 (6) - MDbg를 이용한 방법 [2]파일 다운로드1
1533정성태11/12/201333756기타: 39. Internet Explorer 11에서 유튜브 동영상의 1080p 옵션이 보이지 않는 경우 [5]
1532정성태11/5/201334674Phone: 8. 안드로이드용 Xamarin 개발 시 겪을 만한 시행 착오 정리 [6]
1531정성태11/5/201326067VS.NET IDE: 82. Visual Studio에서 Attach 메서드를 이용해 디버깅을 시작한 경우 Breakpoint가 안 잡힌다면?
1530정성태11/5/201327452기타: 38. 오픈소스로 풀린 하드 디스크 관리 도구 - WindowSMART
1529정성태11/5/201323342오류 유형: 192. SQL 서버 - The transaction log for database '...' is full due to 'LOG_BACKUP'.
... 136  137  138  139  [140]  141  142  143  144  145  146  147  148  149  150  ...