Microsoft MVP성태의 닷넷 이야기
C#과 WIN32 API 관계 질문드립니다. [링크 복사], [링크+제목 복사],
조회: 3484
글쓴 사람
한예지 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"가 완전히 동일하게 그 그림의 역할을 하고 있으니 같은 것입니다.
정성태

1  2  3  4  5  6  7  8  9  10  11  [12]  13  14  15  ...
NoWriterDateCnt.TitleFile(s)
5648주니어개...4/13/20223936컴파일된 코드를 원시코드로 바꾸려면 어떻게해야하나요? [1]파일 다운로드1
5647장성욱4/7/20223975코어지정 CPU사용률 관련 질문 [1]
5646서형주4/6/20224008List에 여러개의 class 객체를 만들어 넣을때, 객체의 method들도 같이 생성되어 메모리를 차지하나요? [1]
5645김인태4/6/20223646윈도우즈 서버의 AD 계정 생성 조건이 있을까요? [1]
5644ㅇㅇ4/6/20224405c# 프로그램을 이용하여 리눅스상에 파일 생성이 가능한가요? [1]
5643유필재4/5/20224266TCP클라이언트 연결 및 통신관련하여 문의드려요 [1]
5642차가워4/4/20224519UdpClient 패킷 수신 문의 [4]
5641장성욱4/4/20224938코어 할당 및 cpu 부하테스트 질문 [7]
5640icoo...4/4/20224471웹가든에서 메모리 동적 업데이트 방법 [1]
5639차가워4/4/20224361c++ 서버 c# 클라이언트 호환 문의 [1]
5638초급4/3/20224659c# sql server 연동 [1]
5637따봉이4/1/20224931Winform Form Load 후 자동 캡쳐관련 [1]파일 다운로드1
5636김철순3/31/20224913WPF에서 Richtext의 View 문의 [5]
5635guest3/30/20224943안정적인 pinning이 가능하네요. [3]파일 다운로드1
5633꿀주세요3/30/20224596선생님 마우스 클릭이벤트 질문이 있습니다. [4]
5632김현수3/30/20224928Remote Desktop으로 접속시 WPF UI 가 다시 그려지는 이벤트를 막을 수 없을까요? [3]
5631김기헌3/24/20224563WPF 컨트롤의 그래픽 처리관련 질문드립니다 [2]파일 다운로드1
5630장성욱3/24/20224388로깅관련 질문입니다. [2]
5629감사합니...3/23/20224637함수에서 예외가 발생하면 try ~ catch처리기를 찾을 때 까지 상위 함수로 계속 올라가나요? [2]
5628홍길동3/23/20225295질문드립니다. [2]파일 다운로드1
5626연준혁3/21/20224494안녕하세요. [3]
5625jaew...3/18/20225429c# 8.0 도서를 구입한 사람입니다. [1]
5624초보자3/17/20224394람다 캡처 관련 문의 [2]
5623한예지 donator3/15/20224778인터프리터 원리가 궁금합니다. [4]
5622김민아3/8/20224716const와 readonly의 명확한 차이가 이게 맞나요? [2]
5621장성욱3/8/20224522c# 로그 관련 질문 [1]
1  2  3  4  5  6  7  8  9  10  11  [12]  13  14  15  ...