Microsoft MVP성태의 닷넷 이야기
wpf의 ICommand 질문 입니다. [링크 복사], [링크+제목 복사]
조회: 12031
글쓴 사람
popo
홈페이지
첨부 파일
(연관된 글이 1개 있습니다.)

안녕하세요.

ICommand를 구현해서 특정 컨트롤에 Command처리를 하고 Execute()와 CanExecute() 메서드를 구현했을때

CanExecute Command 이벤트가 키보드와 마우스 Input이 감지 될때마다 매번 항상 발생 되는 것을 확인 할 수 있는데요

당연히 또 Execute Command가 실행 될 수 있는지 여부를 따질려면 매번 발생되는 것이 맞다고 생각하고 있습니다.

그런데 Command처리를 MVVM패턴으로

View에 Command바인딩 처리를 해놓고 ViewModel에 Execute()와 CanExecute()를 구현해 놓았을때

해당 View가 Close되고 더 이상 사용되지 않은 경우에도 매번 CanExecute Command 이벤트가 발생되는 것을 확인 할 수 있었습니다.

이 것이 여러개의 많은 Command가 사용되는 경우 메모리 누수 같은 영향을 끼치거나 CanExecute()안에 여러 개체를 참조하는 로직이 포함되어 있는 경우

심각한 문제가 될 수 있다고 생각하는데요..

이러한 상황 같은 경우는 어떻게 처리를 해야 하면 좋을지 질문 남겨 봅니다.

정리 하자면 MVVM패턴 사용시 해당 View가 제거 될때 ViewModel 정리 및 Command 이벤트 정리를 효과적으로 하려면 어떻게 하는 것이 좋은 것 인지 답변 부탁드립니다.


제가 테스트했던 파일 첨부 하겠습니다.

Window1이 닫힌 상태에서도 Window1ViewModel에 CanExecuteTestSendMailCommand가 매번 호출 되는 것을 확인했습니다.


[연관 글]






[최초 등록일: ]
[최종 수정일: 3/9/2016]


비밀번호

댓글 작성자
 



2016-03-09 03시03분
문답으로 풀어볼까요? ^^ 우선, Window1이 닫혔는데도 CanExecuteTestSendMailCommand가 발생하는 이유가 뭘까요? ^^ (참고로, 현재 예제가 GalaGalaSoft.MvvmLight를 사용해서 복잡한데, 간략하게 자신이 만든 ICommand로 구현해 보세요.)
정성태
2016-03-10 01시04분
[글쓴이] 답변 감사 드립니다.

처음엔 단순히 Command가 변경될때나 키보드의 KeyUp 이벤트, 마우스 Click이벤트가 발생될때 CommandManager.RequerySuggested 이벤트가 자동적으로 호출되어 CanExecute가 매번 발생 되는 것이라고만 생각 했었는데

이상하게 Window1이 닫혔는데도 CanExecute가 왜 매번 발생되는지 생각해보니 CommandManager.RequerySuggested가 static으로 되어 있는 것 을 확인했습니다.

그래서 매번 발생이 되는 것 같았습니다. (제가 정확하게 추측했는지는 모르겠네요..ㅠ)

그렇다면 명시적으로 CommandManager.RequerySuggested 이벤트가 제거가 되어야 하는데

ICommand의 CanExecuteChanged이벤트에 remove는 언제 호출이 되는 것인지 몰르겠습니다.

매번 여러 화면에서 명시적으로 window가 닫힐때 CommandManager에서 직접 제거하는 코드를 넣는 것은 또 아닌 것 같구요..

답변 부탁드립니다.
(예제의 window1에 버튼 Command는 GalaGalaSoft.MvvmLight와 상관 없이 직접 ICommand로 구현 되어 있는 DelegateCommand를 사용하고 있습니다.)
[guest]
2016-03-10 02시23분
이게 문제가 있군요. CanExecuteChanged는 일단 해제해 주어야 합니다. 아니면, 윈도우가 닫힐 때 명시적으로 DataContext 속성을 (Closed 이벤트 등의 시점에) null로 설정해 주어야 합니다. 어쨌든, CommandManager.RequerySuggested 와 DataContext != null인 상황이 맞물리면 그와 같이 Window 자원이 정상적으로 해제되지 않는 문제가 있습니다. (아마도, 내부적으로 복잡한 상호 참조 문제가 있는 듯 한데... 더 이상은 알 수 없군요.)

(그리고, 예제 코드는 간결하게 올려주실수록 좋습니다. 문제가 발생한 곳의 코드는 간단하다고 해도 처음 그 코드를 보는 사람들은 다른 코드가 방해될 수밖에 없습니다. 그래서, 최소한의 예제 코드를 올려달라고 부탁드리는 것입니다.)
정성태
2016-03-10 05시56분
[글쓴이] 답변 감사드립니다.

그렇다면 말씀해주신 "CommandManager.RequerySuggested 와 DataContext != null인 상황이 맞물리면 그와 같이 Window 자원이 정상적으로 해제되지 않는 문제가 있습니다."

이 부분은 .net의 버그로 보아야 하는 것인건가요..?ㅠ

첨부 예제를 최소한의 예제 코드로 올리지 못한점은 죄송합니다..
[guest]
2016-03-10 03시46분
그러게요... 버그라고 보는 것이 맞겠지요! 일단 다음의 글로 정리해 두었으니 참고하세요.

WPF - ICommand.CanExecuteChanged가 해제되지 않는 문제
; http://www.sysnet.pe.kr/2/0/10918
정성태

... 16  17  18  19  20  21  22  23  [24]  25  26  27  28  29  30  ...
NoWriterDateCnt.TitleFile(s)
5317kskk...4/7/20209032OpenCV 이용 해상도 설정 질문 입니다.. [3]
5316윤현수4/7/20206256pipe 비동기방식 질문 [1]파일 다운로드1
53154/6/20206921dll파일 로드 원리? 부분에서 도움받고싶습니다. [3]
5314강성욱3/31/20208825메서드 내에서 await 2번 등장할 때의 이해 [11]파일 다운로드1
5313강성욱3/27/20206631await 2번 [1]
53121a2a...3/20/20206410Re raw data write 질문 관련 [1]파일 다운로드1
53111a2a...3/20/20207215Raw data write 관련 질문 [1]파일 다운로드1
5310아스파넬3/15/202072431초에 5회 함수호출 제한 관련 질문입니다. [1]
5309하태3/11/20209122안녕하십니까. c# Winform UI 질문드리겠습니다! [3]파일 다운로드1
5308질문3/9/20207924Window XP SP3 32bit 환경(Window Update 모두 완료)에서 .Net Framework 4.0.3 으로 빌드된 .dll 파일 gacutil.exe 등록 관련 문의 [5]
5306개발자3/9/20206777C#을 통해 인터넷 접속 가능한 이더넷을 선택할 수 있는지요? [1]
5305JaeS...3/9/20206466RAW파일 생성 질문드립니다 [8]파일 다운로드1
5303궁금하당2/27/20208762C#에서 C++ DLL읽기 (아래 글쓴이) [1]
5302궁금하당2/27/202010846C#에서 C++ DLL호출 ('PInvokeStackImbalance') [4]파일 다운로드1
5301질문합니...2/27/20206327소켓 대량 데이터 디자인 문의 [1]
5300nals...2/27/20206955vs2013에서 BinaryFormatter Serialize 후 vs2015에서 Deserialize시 예외 발생 [3]파일 다운로드1
5298질문2/26/20208340.lic 파일에 대해 질문 있습니다. [9]
5297임한승2/26/20205907vs2013에서 BinaryFormatter Serialize 후 vs2015에서 Deserialize시 예외 발생 건 [1]파일 다운로드1
5295나그네2/25/20207332클라이언트 PC 정보 조회관련.. [2]
5294닷넷초보ㅠ2/25/20207314윈폼으로 socket통신프로그램 만든후 release로 디버깅한 실행파일을 다른컴퓨터에서 실행할때 반응이없어요 [1]
5293탱코2/21/20207210검색을 하고 싶은데 어떻게 검색을 해야 할 지 모르겠습니다. [1]
5292아부리2/19/20207124XingApiNet 관련 질문 [3]
5291지현명2/15/20207855JsonConvert.Serialize 하고 Deserialize 할때 간헐적으로 한글 깨짐 현상 문의 합니다. [3]
5290베도빈2/15/20207201직접 제작한 사용자 정의 콘트롤 DLL, 실행파일에 포함시켜 배포할 수 있을까요? [1]
5288김성배2/14/20207615c# 참조추가 기능에서 DirectX 참조가 보이지 않아요.. DircetX 11 은 설치 되어 있습니다. [1]
5287C# 초...2/14/20206622프로그램 실행 질문 드립니다. [4]파일 다운로드1
... 16  17  18  19  20  21  22  23  [24]  25  26  27  28  29  30  ...