Microsoft MVP성태의 닷넷 이야기
글쓴 사람
정성태 (techsharer at outlook.com)
홈페이지
첨부 파일
 


의존 속성 정의에서 XamlParseException 발생하는 예


아래는 DependencyProperty를 만드는 전형적인 코드입니다.

public partial class Window1 : Window
{
    public static readonly DependencyProperty OADTimeProperty =
         DependencyProperty.Register("OADTime", typeof(double), typeof(Window1),
         new FrameworkPropertyMetadata(0, OnPropertyChanged));

    public double OADTime
    {
        get { return (double)this.GetValue(OADTimeProperty); }
        set { this.SetValue(OADTimeProperty, value); }
    }

    private static void OnPropertyChanged(DependencyObject obj, DependencyPropertyChangedEventArgs args)
    {
    }

    public Window1()
    {
        InitializeComponent();
    }
}

그런데, 위와 같이 정의하고 빌드하면 오류가 발생합니다.

[그림 1: 의존 속성 정의에서 오류가 발생한 경우]
default_value_wpf_dp_1.PNG

Cannot create instance of 'Window1' defined in assembly 'WpfApplication1, Version=1.0.0.0, Culture=neutral, PublicKeyToken=null'. Exception has been thrown by the target of an invocation. Error in markup file 'Window1.xaml' Line 1 Position 9.



아래의 내용을 더 살펴보기 전에... 오류의 원인이 무엇일까 잠시 생각해 보시는 것도 좋겠지요. ^^




불행히도, 라인 정보도 없이 위와 같이 달랑 XamlParseException이 떨어지니 어디서 손을 대야 할지 모르는데요. 예전에 알려드린 "WPF - XamlParseException 대응 방법"에서 쓴 것처럼 "First-chance exception"을 Output 윈도우에서 찾아보면 "ArgumentException"이 발생한 것을 알 수 있습니다. 그래서 이 예외를 throw 하도록 설정한 후 다시 프로그램을 실행시켜 보면 아래와 같이 좀 더 친절한 예외 정보를 볼 수 있습니다.

[그림 2: ArgumentException]
default_value_wpf_dp_2.PNG

"
System.ArgumentException occurred
Message="Default value type does not match type of property 'OADTime'."
Source="WindowsBase"
StackTrace:
...[이하 생략]...
"



아하... 기본값 설정이 잘못 되었습니다. typeof(double) 형으로 지정했는데, integer 값인 0이 잘못되었다고 불평하는 것입니다. 좀 심하군요. ^^; 심지어 "0.0f"라고 해서 float 형으로 지정해도 안됩니다. 정확하게 "0.0"으로 지정해 주어야 합니다.

DateTime이나 기타 struct와 같은 것들도 고려해보면 왠지 좀 귀찮을 것 같은 느낌이 드는데요. 이런 경우 써먹을 수 있는 좋은 키워드가 바로 "default"입니다. 따라서, 위의 OADTime DP를 다시 아래와 같이 정의해 주어도 됩니다.

public static readonly DependencyProperty OADTimeProperty =
     DependencyProperty.Register("OADTime", typeof(double), typeof(Window1),
     new FrameworkPropertyMetadata(default(double), OnPropertyChanged));




잠시 생각난 퀴즈 하나!

C#에서 멤버 변수를 정의할 때, 아래와 같이 access modifier를 생략하면,

class Test
{
    int Name;
}

Name은 기본적으로 private 접근 제한자가 적용된다는 것은... 다들 아시지요. 여기서 문제입니다. 보시는 것처럼 위의 "Test" 클래스도 역시 접근 제한자가 생략되어 있는데요. 이건 기본값이 어떤 access modifier가 적용될까요?



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







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

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

비밀번호

댓글 작성자
 



2009-01-05 02시53분
[jakard] 클래스의 기본 access modifier는 internal이 아닌가요? 매번 좋은 글 잘 읽고 있습니다.
[guest]
2009-01-05 03시09분
^^ 맞습니다.

Jakard's Tistory
; http://jakard.tistory.com/
kevin25

... 121  122  123  124  125  126  127  128  129  [130]  131  132  133  134  135  ...
NoWriterDateCnt.TitleFile(s)
1838정성태1/4/201541482기타: 49. 윈도우 내레이터(Narrator) 기능 끄는 방법(윈도우에 파란색의 굵은 테두리 선이 나타난다면?) [4]
1837정성태1/4/201527665디버깅 기술: 68. windbg 분석 사례 - 메모리 부족 [1]
1836정성태1/4/201527618디버깅 기술: 67. windbg - 덤프 파일과 handle 정보
1835정성태1/3/201528164개발 환경 구성: 254. SQL 서버 역시 SSL 3.0/TLS 1.0만을 지원하는 듯!
1834정성태1/3/201552789개발 환경 구성: 253. TLS 1.2를 적용한 IIS 웹 사이트 구성
1833정성태1/3/201528961.NET Framework: 490. System.Data.SqlClient는 SSL 3.0/TLS 1.0만 지원하는 듯! [3]
1832정성태1/2/201521614오류 유형: 266. Azure에 응용 프로그램 게시 중 로그인 오류
1831정성태1/1/201529751디버깅 기술: 66. windbg 분석 사례 - cpu 100% 현상 (1) [1]
1830정성태1/1/201528870오류 유형: 265. svchost.exe 프로세스(IP Helper: IPHLPSVC)의 CPU 100% 현상
1829정성태12/16/201432676VC++: 86. Windows Vista부터 바뀐 Credential Provider 예제 분석 (2) [2]파일 다운로드1
1828정성태12/15/201429143VC++: 85. Windows Vista부터 바뀐 Credential Provider 예제 분석 (1) [4]파일 다운로드1
1827정성태12/12/201425513VC++: 84. CredUIPromptForWindowsCredentials Win32 API 사용법 정리
1826정성태12/11/201429863.NET Framework: 489. Socket.Listen에 전달된 backlog 인자의 의미 [6]
1825정성태12/11/201477371.NET Framework: 488. TCP 소켓 연결의 해제를 알 수 있는 방법 [10]파일 다운로드1
1824정성태12/10/201427129.NET Framework: 487. Socket.Receive 메서드의 SocketFlags.Peek 동작을 이용해 소켓 연결 유무를 확인? [8]파일 다운로드1
1823정성태12/10/201424138.NET Framework: 486. Java의 ScheduledExecutorService에 대응하는 C#의 System.Threading.Timer [2]
1822정성태12/3/201426317개발 환경 구성: 252. Xamarin 라이선스 관리 [8]
1821정성태12/1/201433130VS.NET IDE: 96. Visual Studio에서 /* ~ */ 주석을 위한 단축키(매크로)
1820정성태11/23/201421386.NET Framework: 485. Mono Profiler에서 IL 코드 변경이 가능할까? - 두 번째 이야기파일 다운로드1
1819정성태11/22/201421213오류 유형: 264. MSBuild 에러 - warning MSB3052: The parameter to the compiler is invalid,
1818정성태11/22/201424173개발 환경 구성: 251. NUMA 노드 수에 따른 IIS Worker Process(w3wp.exe) 설정 [1]
1817정성태11/22/201427268VS.NET IDE: 95. Macros for Visual Studio 2013 [1]
1816정성태11/20/201421964.NET Framework: 484. Mono Profiler에서 IL 코드 변경이 가능할까?
1815정성태11/18/201419969.NET Framework: 483. 코드로 살펴 보는 ETW의 활성화 시점 [2]
1814정성태11/18/201421476오류 유형: 263. Unable to find the requested .Net Framework Data Provider. It may not be installed.
1813정성태11/18/201423205오류 유형: 262. Build Events에 robocopy 작업이 있는 경우 "VCEnd exited with code 3" 오류 발생
... 121  122  123  124  125  126  127  128  129  [130]  131  132  133  134  135  ...