Microsoft MVP성태의 닷넷 이야기
C#과 WIN32 API 관계 질문드립니다. [링크 복사], [링크+제목 복사],
조회: 12823
글쓴 사람
한예지 donator
홈페이지
첨부 파일
 

선생님 안녕하세요.
UI 요소의 접근은 반드시 그 UI를 만든 스레드에서 : 2번째 이야기
( https://www.sysnet.pe.kr/2/0/12537#17061 ) 에서 해주신
답변을 이해하고자 윈도우 프로그래밍 책 한 권을 처음부터 끝까지 읽고
선생님의 예전 글들을 다시 읽으니까 새롭게 보이더고요.
그리고 "Winform은 결국 WIN32 API를 Wrapping해서 사용하는 것에 불구하다(?)."라는 느낌을 받았습니다.

인터넷, 책 찾아보고 해결 안 된 몇 가지 궁금사항을 선생님께 질문드리고자 합니다.

[질문 ①]
책이나 인터넷에서 WIN32 메시지 구동 구조를 설명할 때 보통 아래 두 가지 타입으로 설명하더라구요.
① System Message Queue → Application Message Queue → Message Loop → Window Procedure
② System Message Queue → Thread Message Queue      → Message Loop → Window Procedure
여기서 제가 궁금한 점은 Application Message Queue, Thread Message Queue 차이점입니다.
A라는 어플리케이션에 메시지 루프를 가진 UI 스레드가 하나라면
Application Message Queue와 Thread Message Queue가 동일하다고 볼 수 있지만
A라는 어플리케이션에 메시지 루프를 가진 UI 스레드가 2개라면
Application Message Queue와 Thread Message Queue는 같지 않다고 생각하는데
혹시 Thread Message Queue 여러 개를 묶어서 그냥 Application Message Queue라고 표현할까요?
(UI 스레드 2개를 만드는 방법은 https://www.sysnet.pe.kr/2/0/11287를 참고했습니다)


[질문 ②]
Application.Run()가 실행하는 메시지 루프에서 GetMessage 메서드를 통해
메시지 큐에서 메시지를 꺼낸다고 하는데
이때 메시지 큐는 threadCallbackList를 의미하나요?
public partial class Control {
    // ...[생략]...
    
    private Queue threadCallbackList;
    
    // ...[생략]...
}

[질문 ③]
새 프로젝트 템플릿 중에서 Windows Forms Application을 선택하면 폼 하나가 띄워집니다.
폼 위에 Button, TextBox, Label을 올려놓습니다.
폼 위에 올려놓은 3개의 컨트롤 Button, TextBox, Label은
Control 클래스를 상속받기 때문에
"질문 ②"에서 언급한 하나의 threadCallbackList 큐를 공유하는 게 맞을까요?

[질문 ④]
Message Loop를 구동하는 메인 스레드를 UI 스레드가 부르는데
이때 UI 스레드가 담당하는 메시지 큐는 어떤 경우에도 1개가 맞을까요?
(여기서 언급하는 큐는 시스템 큐가 아니라 질문 ①에서 언급한 Thread Message Queue
 혹은 Application Message Queue를 의미합니다.)








[최초 등록일: ]
[최종 수정일: 10/3/2023]


비밀번호

댓글 작성자
 



2023-10-04 09시53분
[답변 1] 혹시 2가지 방식으로 동작 구조를 설명한다는 책 또는 인터넷 문서를 알려주실 수 있을까요? 공식 문서에 보면,

About Messages and Message Queues
; https://learn.microsoft.com/en-us/windows/win32/winmsg/about-messages-and-message-queues

"Application Message Queue"라는 문구가 한 번 나오는데 그것도 의미상으로는 Thread Message Queue에 해당합니다. 지금은 docs/learn 사이트가 많이 개편돼 예전 MSDN 시절의 문서가 사라져서 오히려 시스템 레벨의 내용을 찾기가 힘들어졌습니다. 언뜻 제 기억으로는 Thread Message Queue가 메시지의 종류에 따라 여러 개를 갖고 있으며, 아마도 그중의 하나가 Application Message Queue라고 불릴 수 있을 듯합니다. (마지막 의견은 공식적으로 확인된 사항이 아닙니다.)

[답변 2] GetMessage가 다루는 대상은 (공식 문서상으로는) Thread Message Queue입니다. 첨부한 Control 클래스의 소스 코드는 닷넷의 코드일 텐데, GetMessage는 닷넷의 존재를 알지 못합니다.

[답변 3] 1개의 스레드에서 생성한 Form, Button, TextBox, Label이 있는 것이고 그것은 동일한 Thread Message Queue를 공유합니다. (공유한다는 표현보다는, 한 개의 스레드 메시지 큐에 의해 동작한다는 것이 올바른 표현이겠군요.)

[답변 4] 답변 2에 따라 GetMessage는 해당 Thread와 연결된 메시지 큐를 대상으로 하기 때문에 1개가 맞습니다.
정성태
2023-10-04 09시40분
책 혹은 인터넷에서 Windows Message Queue를 설명할 때 사용하는 그림은 크게 2가지입니다.
Application Message Queue 그림을 사용하거나
혹은 선생님께서 말씀하신 Thread Message Queue 그림을 사용한 것입니다.

아래 블로그는 Application Message Queue 그림을 사용한 것입니다.
https://flylib.com/books/en/2.906.1.18/1/
https://webocreation.com/anatomy-of-a-windows-based-application/#gsc.tab=0
쉽게 배우는 MFC 윈도우 프로그래밍[김선우] 44, 45쪽도 위의 블로그와 동일한
Application Message Queue 그림을 사용해서 설명하고 있습니다.

API로 배우는 Windows 구조와 원리[야스무로 히로카즈] 56, 57쪽에는
Thread Message Queue 그림을 사용해서 설명하고 있습니다.

답변해 주셔서 정말 감사합니다.^^
한예지
2023-10-04 10시28분
Application Message Queue 그림, Thread Message Queue 그림 모두 완전히 동일한 그림입니다.
딱 한 가지 차이점은 Thread Message Queue 그림은
Application Message Queue 단어 대신 Thread Message Queue 단어를 사용했다는 것입니다.
한예지
2023-10-04 11시58분
인용하신 자료가 상당히 오래된 걸로 봐서, 당시에는 "Application Message Queue"로 명명한 듯합니다. 현재는 "Thread Message Queue"가 완전히 동일하게 그 그림의 역할을 하고 있으니 같은 것입니다.
정성태

... 76  77  78  79  80  81  82  83  84  [85]  86  87  88  89  90  ...
NoWriterDateCnt.TitleFile(s)
357정성태4/25/200612060            답변글 [답변]: [답변]: 귀찮게 해드려 죄송스럽지만. [1]
352산들바람4/19/200611727이번겨울방학때세도나를 여행하려구하는데요,,,
353정성태4/20/200619055    답변글 [답변]: 이번겨울방학때세도나를 여행하려구하는데요,,,
351오기4/18/200611499aspx [2]
350유지연4/17/200612223smartclient DB connection관련 질문 입니다. [2]파일 다운로드1
349선재빠4/17/200612156object tag를 2개 넣으면 IE가 죽어버리네요. [2]
347박찬용4/13/200612204COM+에 관한 질문입니다. [2]
345선재빠4/11/200612985Winform을 띄울 수 있는 방법이 있나요? [3]
344선재빠4/10/200614194ASP.NET 2.0에서는 VIEWASTEXT 이란 태그옵션을 지원하지 않는군요 [3]
343선재빠4/10/200613393아래와 같은 에러가 나네요.
341선재빠4/8/200613090테스트 페이지를 보면 프레임만 나오고 안에 내용이 나오지 않는군요 [1]
340김형태4/4/200612237파일서버 관련 질문드립니다.. (데브피아 답변에 이어) [2]
339조남정4/4/200612360post 주소 읽어오기 [1]
338장두헌4/4/200613945SDK PlatForm 다시 질문 - 데브피아의 내용 [1]
337강완모4/3/200614209Cab파일이 아닌 설치용 파일로 OCX들 설치하기... [1]
335비니3/23/200615274밑에 Smart Client에 대해서 질문했던 초보입니다.. TreeView컨트롤은 보이는데 안에 내용이 안보여요. [1]
336비니3/24/200613104    답변글 [재질문]:자꾸 죄송합니다...링크페이지로 이동을 안해요.... [1]
334비니3/23/200612741Smart Client강의 따라해보다가 xml에서 활성스키마는 <Tree>,<L> 요소는 지원하지 않는다고 나와요.ㅠㅠ [1]
332정준명3/21/200612790[자문자답] VS.NET에서 COM을 참조했는데, 강력한 서명이 없다고 사용불가네요.
333정성태3/22/200611232    답변글 [답변]: [자문자답] VS.NET에서 COM을 참조했는데, 강력한 서명이 없다고 사용불가네요. [1]
330심현철3/3/200614398[질문] VS2005에서 C#으로 개발한 DLL을 Javascript에서 접근할 수 없습니다. (ActiveX with C#) [2]
329권인성2/27/200612424스마트클라이언트(clickonce) 버전관리 [1]
327권인성2/24/200612210clickonce를 통해 설치 및 업데이트하려고 하는데요...보안때문에요..
331정성태3/12/200613293    답변글 [답변]: clickonce를 통해 설치 및 업데이트하려고 하는데요...보안때문에요..
325권인성2/23/200611827SETUP 및 배포관련 [1]
326권인성2/23/200611357    답변글 [답변]: 한가지만 더 질문할게요.... [1]
... 76  77  78  79  80  81  82  83  84  [85]  86  87  88  89  90  ...