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]

... 61  62  63  64  65  66  67  68  69  70  71  72  [73]  74  75  ...
NoWriterDateCnt.TitleFile(s)
11805정성태1/28/201913774.NET Framework: 806. C# - int []와 object []의 차이로 이해하는 제네릭의 필요성 [4]파일 다운로드1
11804정성태1/24/201911807Windows: 155. diskpart - remove letter 이후 재부팅 시 다시 드라이브 문자가 할당되는 경우
11803정성태1/10/201911303디버깅 기술: 121. windbg - 닷넷 Finalizer 스레드가 멈춰있는 현상
11802정성태1/7/201912681.NET Framework: 805. 두 개의 윈도우를 각각 실행하는 방법(Windows Forms, WPF)파일 다운로드1
11801정성태1/1/201913566개발 환경 구성: 427. Netsh의 네트워크 모니터링 기능 [3]
11800정성태12/28/201812907오류 유형: 509. WCF 호출 오류 메시지 - System.ServiceModel.CommunicationException: Internal Server Error
11799정성태12/19/201813742.NET Framework: 804. WPF(또는 WinForm)에서 UWP UI 구성 요소 사용하는 방법 [3]파일 다운로드1
11798정성태12/19/201812918개발 환경 구성: 426. vcpkg - "Building vcpkg.exe failed. Please ensure you have installed Visual Studio with the Desktop C++ workload and the Windows SDK for Desktop C++"
11797정성태12/19/201810316개발 환경 구성: 425. vcpkg - CMake Error: Problem with archive_write_header(): Can't create '' 빌드 오류
11796정성태12/19/20189971개발 환경 구성: 424. vcpkg - "File does not have expected hash" 오류를 무시하는 방법
11795정성태12/19/201812349Windows: 154. PowerShell - Zone 별로 DNS 레코드 유형 정보 조회 [1]
11794정성태12/16/20189806오류 유형: 508. Get-AzureWebsite : Request to a downlevel service failed.
11793정성태12/16/201811399개발 환경 구성: 423. NuGet 패키지 제작 - Native와 Managed DLL을 분리하는 방법 [1]
11792정성태12/11/201812190Graphics: 34. .NET으로 구현하는 OpenGL (11) - Per-Pixel Lighting파일 다운로드1
11791정성태12/11/201812158VS.NET IDE: 130. C/C++ 프로젝트의 시작 프로그램으로 .NET Core EXE를 지정하는 경우 닷넷 디버깅이 안 되는 문제 [1]
11790정성태12/11/201810539오류 유형: 507. Could not save daemon configuration to C:\ProgramData\Docker\config\daemon.json: Access to the path 'C:\ProgramData\Docker\config' is denied.
11789정성태12/10/201820370Windows: 153. C# - USB 장치의 연결 및 해제 알림을 위한 WM_DEVICECHANGE 메시지 처리 [2]파일 다운로드2
11788정성태12/4/201810354오류 유형: 506. SqlClient - Value was either too large or too small for an Int32.Couldn't store <2151292191> in ... Column
11787정성태11/29/201814290Graphics: 33. .NET으로 구현하는 OpenGL (9), (10) - OBJ File Format, Loading 3D Models파일 다운로드1
11786정성태11/29/201811055오류 유형: 505. OpenGL.NET 예제 실행 시 "Managed Debugging Assistant 'CallbackOnCollectedDelegate'" 예외 발생
11785정성태11/21/201813422디버깅 기술: 120. windbg 분석 사례 - ODP.NET 사용 시 Finalizer에서 System.AccessViolationException 예외 발생으로 인한 비정상 종료
11784정성태11/18/201813070Graphics: 32. .NET으로 구현하는 OpenGL (7), (8) - Matrices and Uniform Variables, Model, View & Projection Matrices파일 다운로드1
11783정성태11/18/201811203오류 유형: 504. 윈도우 환경에서 docker가 설치된 컴퓨터 간의 ping IP 주소 풀이 오류
11782정성태11/18/201810975Windows: 152. 윈도우 10에서 사라진 "Adapters and Bindings" 네트워크 우선순위 조정 기능 - 두 번째 이야기
11781정성태11/17/201813170개발 환경 구성: 422. SFML.NET 라이브러리 설정 방법 [1]파일 다운로드1
11780정성태11/17/201814650오류 유형: 503. vcpkg install bzip2 빌드 에러 - "Error: Building package bzip2:x86-windows failed with: BUILD_FAILED"
... 61  62  63  64  65  66  67  68  69  70  71  72  [73]  74  75  ...