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

... 46  [47]  48  49  50  51  52  53  54  55  56  57  58  59  60  ...
NoWriterDateCnt.TitleFile(s)
3667김치사발면12/15/201510925템플릿 설정 추가 질문 [1]파일 다운로드1
3666노태현12/15/201510341사용자별로 권한을 주고 볼 수 있는 데이터를 제한하려면 어떤 방법으로 접근하는게 좋을까요? [2]
3665김치사발면12/14/201513436C# 템플릿 설정이 이상해요ㅜㅜ [3]파일 다운로드1
3664KuLu12/10/201510719멀정하던 사이트 중 일부메뉴가 응답없음이 되어버립니다. [3]
3663Sung...12/10/201512077UWP 서버 프로그래밍 작업 중 [5]
3662Sung...12/9/201511927uwp앱에서 접속한 클라이언트 주소값을 받아서 표시하고 싶은데 어떤 메소드를 써야 할까요? [7]
3661김무진12/9/201511260Oracle 환경에서 데이터를 조회할때 한글이 ? 이렇게 표시가됩니다. [1]
3660질문자12/7/201513185OpenFileDialog 호출시 hang걸리는 문제 [4]
3659Sung...12/4/201512821UWP 앱에서 textBox로 클라에서 받은 값을 나타내고 싶은데 안되고 있습니다. [5]
3658강준12/3/201512067Visual Studio (Xamarin) vs Eclipse [2]
3656DEVY...12/1/201510971MasterPageFile 사용시 다국어 처리 질문입니다. [1]
3653DEVY...11/26/201512433ds:Signature 질문입니다. [7]
3654윤용한11/27/201512172    답변글 [답변]: ds:Signature 질문입니다. [3]
3657윤용한12/1/201514461    답변글 [답변]: ds:Signature 질문입니다. [1]
3651노태현11/20/201545165MariaDB - ASP.NET오류의 원인조차 못 찾고 있습니다.. [2]파일 다운로드2
3652노태현11/20/201512046    답변글 [답변]: MariaDB - ASP.NET오류의 원인조차 못 찾고 있습니다.. [3]
3649kokon11/17/201512464예제 파일 실행이 안 되네요 [5]
3647Sang...11/15/201510977Part 3 목차? [5]
3646힘찬도약11/13/201515817c# mscorlib System.IO IOException [8]파일 다운로드2
3644힘찬도약11/11/201514959c# user.config파일 [2]
3645spow...11/13/201511967    답변글 [답변]: c# user.config파일 - Json.NET을 이용한 설정파일 처리 [1]파일 다운로드1
3643힘찬도약11/11/201513769C# 함수의 processing time과 재호출 [14]
3642.net11/10/201512446c# 으로 작성된 com+ 에 대한 문제입니다. [2]
3641힘참도약11/9/201512887c# log file 관련해서 질문드립니다. [5]
3638윤창선11/4/201513459사설IP가 부여된 무선라우터간 영상전송 관련 문의 [8]
3634Hyun...11/2/201510992c# 에서 webkit browser에서 webgl을 이용하는 사이트에 접속이 안됩니다. [1]
... 46  [47]  48  49  50  51  52  53  54  55  56  57  58  59  60  ...