Microsoft MVP성태의 닷넷 이야기
이벤트 핸들러와 쓰레드의 관계 2 [링크 복사], [링크+제목 복사],
조회: 19487
글쓴 사람
임동찬 (techsharer at outlook.com)
홈페이지
첨부 파일

아래 답변 감사드립니다.
링크 주신 게시글 보며 확인해봤는데
아래 두가지 점에 대해 궁금합니다.

1. 첫번째 링크의 예제에서 이벤트를 2개 아닌 1개만 등록시키면,
   watch창에서 _invocationCount가 1이 아닌 0으로 나오네요?
   reflection을 통해서는 1개 등록시에도 잘 나오구요.
   (.net framework 내부에서 2개 이상일때만 _invocationList를 통해 관리하는 건지...?)

2. 위와 같이 테스트 해도 원래 질문은 해결되지 않네요.
   첨부파일은 첫번째 링크 예제에 event를 주기적으로 fire시키도록 추가한 예제인데,
   실제 디버그모드에서 thread 창을 열어두고 계속 핸들러쪽으로 브레이크 포인트 잡아보면,
   하나의 worker 쓰레드가 아닌 여러개(보통 3개 내외) 쓰레드에서 핸들러가 실행됨을
   확인할 수 있습니다. 왜 그럴까요? 알려주신 방법으로는 명확하게 1개의 구독자만 등록됨을
   확인할 수 있지만 쓰레드는 왜 여러개에서...?








[최초 등록일: ]
[최종 수정일: 1/13/2010]


비밀번호

댓글 작성자
 



2010-01-13 11시34분
[임동찬] 첨부가 안되네요. 저희쪽 문제인듯. 메일로 보냅니다.
[guest]
2010-01-13 07시48분
1. 넵. 한개일 때는 단순히 delegate 변수에 대입해서 처리하는 것 같고, 2개 이상일 때에만 리스트로 관리하는 것 같습니다.
2. 보내주신 예제에서는 여러 개의 쓰레드에서 무작위로 실행되는 것이 맞습니다. 왜냐 하면 Systerm.Timers.Timer 는 내부적으로 쓰레드 풀의 쓰레드를 이용해서 이벤트 핸들러를 호출하기 때문입니다. 만약, UI 쓰레드에서 이벤트 핸들러가 실행하도록 하고 싶다면 System.Windows.Forms.Timer 를 이용하시면 됩니다.
kevin25
2010-01-13 08시19분
[임동찬] 타이머 핸들러가 아닌 테스트 이벤트 핸들러가 그런데요??
[guest]
2010-01-13 10시29분
일반 핸들러가 fire 되는 코드가 timer 이벤트 핸들러 안에 있으니 마찬가지입니다.
timer 이벤트 핸들러가 쓰레드 풀로부터 선택된 쓰레드 위에서 실행되고 있고, 그 내부의 코드 역시 그 쓰레드가 실행하고 있으니까요. 이벤트 핸들러는 "단어" 자체가 이벤트 핸들러일 뿐 그냥 함수 호출이라고 보시면 됩니다. 즉,

private void tickTimer_Elapsed(object sender, System.Timers.ElapsedEventArgs e)
{
test.TestFire();
}

는,

private void tickTimer_Elapsed(object sender, System.Timers.ElapsedEventArgs e)
{
test_TestEvent(...);
}

라고 보시면 됩니다.
kevin25

... 76  77  [78]  79 
NoWriterDateCnt.TitleFile(s)
105정성태3/2/20059211                            답변글 [답변]: [답변]: 네... 빨리 검토해 봐 주셔서 감사합니다~~
106김용국3/2/20059690                                답변글 [답변]: 답변감사합니다!
91김용국2/28/200511347IE에 WindowsFormControl을 올려 실행하면 이런에러가 나네요???파일 다운로드1
92정성태2/28/200512650    답변글 [답변]: IE에 WindowsFormControl을 올려 실행하면 이런에러가 나네요???
93김용국2/28/200511620        답변글 [답변]: 답변감사합니다... 재질문을 드립니다
94정성태2/28/200512223            답변글 [답변]: [답변]: 답변감사합니다... 재질문을 드립니다
95김용국2/28/200512261                답변글 [답변]: IE주소창에서 해당주소로 실행을 해보니....디버깅 PopUp화면이...^
96정성태2/28/200511292                    답변글 [답변]: [답변]: IE주소창에서 해당주소로 실행을 해보니....디버깅 PopUp화면이...^
97김용국3/1/200511864                        답변글 [답변]: 준비되는데로 말씀드리겠습니다 ^^
84김용국2/21/200512810Smart Client에 관한 문의 드립니다.
87정성태2/22/200512889    답변글 [답변]: Smart Client에 관한 문의 드립니다.
82천호민2/1/200511782데이터 그리드의 템플릿필드에 버튼 컨트롤을 넣구요.. 포스트백시 이전 위치에 포커스를 주고 싶은데요..
83정성태2/2/200512649    답변글 [답변]: 데이터 그리드의 템플릿필드에 버튼 컨트롤을 넣구요.. 포스트백시 이전 위치에 포커스를 주고 싶은데요..
79정형균1/26/200512548드디어 정성태님을 찾았네요..^^; 스마트 클라이언트 구현하는데 배포시 문제때문에 죽겠습니다...
80정성태1/26/200511226    답변글 [답변]: 드디어 정성태님을 찾았네요..^^; 스마트 클라이언트 구현하는데 배포시 문제때문에 죽겠습니다...
76임은선1/25/200512125질문이 있는데요....
77정성태1/25/200512459    답변글 [답변]: 질문이 있는데요....
78임은선1/26/200512989        답변글 [답변]: [답변]: 질문이 있는데요....
62엄길웅10/1/200412704매번 물어보기만 하는군요..
54차광석8/26/200412135잘 지내시죠?
55정성태8/27/200411248    답변글 [답변]: 잘 지내시죠?
45송야5/29/200411763웹페이지 자동로그인..
44반데라이차5/26/200411796안녕하세요~저 오크에요~~^^* [1]
40김대웅2/26/200412929메일 드렸는데.. 읽어보셨는지 모르겠네요.. 많이 바쁘신것 같아요..
41정성태2/29/200411890    답변글 [답변]: 메일 드렸는데.. 읽어보셨는지 모르겠네요.. 많이 바쁘신것 같아요..
32김기영1/5/200411782질문인데요... 웹브라우저로 text를 전송할 수 있을까요??
... 76  77  [78]  79