Microsoft MVP성태의 닷넷 이야기
이벤트 핸들러와 쓰레드의 관계 2 [링크 복사], [링크+제목 복사],
조회: 20716
글쓴 사람
임동찬 (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

... 91  92  93  94  [95]  96  97 
NoWriterDateCnt.TitleFile(s)
78임은선1/26/200513546        답변글 [답변]: [답변]: 질문이 있는데요....
72최정희1/19/200513055또 접니다.
73정성태1/19/200512798    답변글 [답변]: 또 접니다. [2]
74최정희1/19/200512185        답변글 [답변]: [답변]: 당연히 도움이 되지요.
75정성태1/19/200512699            답변글 [답변]: [답변]: [답변]: 당연히 도움이 되지요.
69최정희10/13/200412189저 기억하실런지? 그때 두리로IE툴바 만들어 주셨죠.
62엄길웅10/1/200413329매번 물어보기만 하는군요..
63정성태10/2/200413080    답변글 [답변]: 매번 물어보기만 하는군요..
64keal...10/5/200414772        답변글 [답변]: [답변]: 매번 물어보기만 하는군요..
65정성태10/6/200414580            답변글 [답변]: [답변]: [답변]: 매번 물어보기만 하는군요..
68keal...10/11/200412349                답변글 [답변]: [답변]: [답변]: [답변]: 매번 물어보기만 하는군요..
71정성태10/31/200412417                    답변글 [답변]: [답변]: [답변]: [답변]: [답변]: 매번 물어보기만 하는군요..
58엄길웅9/30/200412554안녕하세요.. 추석은 잘 보내셨는지요?
59정성태9/30/200412632    답변글 [답변]: 안녕하세요.. 추석은 잘 보내셨는지요?
60엄길웅10/1/200412493        답변글 [답변]: [답변]: 안녕하세요.. 추석은 잘 보내셨는지요?
56엄길웅9/23/200412873ATL을 이용해서 함수를 하나 만들었습니다.
57정성태9/23/200413854    답변글 [답변]: ATL을 이용해서 함수를 하나 만들었습니다.
61엄길웅10/1/200412552        답변글 [답변]: [답변]: ATL을 이용해서 함수를 하나 만들었습니다.
54차광석8/26/200412709잘 지내시죠?
55정성태8/27/200411786    답변글 [답변]: 잘 지내시죠?
52김명원8/3/200412648질문이요..
53정성태8/19/200412537    답변글 [답변]: 질문이요..
50김상표7/5/200412321질문요...
51정성태7/6/200412241    답변글 [답변]: 질문요...
45송야5/29/200412389웹페이지 자동로그인..
46정성태5/31/200413295    답변글 [답변]: 웹페이지 자동로그인..
... 91  92  93  94  [95]  96  97