Microsoft MVP성태의 닷넷 이야기
C#과 WIN32 API 관계 질문드립니다. [링크 복사], [링크+제목 복사],
조회: 3489
글쓴 사람
한예지 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)
5832김지우2/21/20233061event와 delegate의 차이 , event를 써야하는 이유 [1]
5831이우람2/20/20233302ref 전역변수가 pinned가 될수 있나요? [2]
5830냉수마찰2/19/20233560C# GridView에 Column별 데이터 추가하는 방법에 대해 [1]
5829수박942/19/20233609키움 API를 윈폼과 WPF의 네임스페이스 없이 콘솔이나 WinUI3에서 사용할 수 있는 방법이 있나요? [2]파일 다운로드1
5828김재영2/19/20233418장기적으로는 this 구문을 안쓰는게 맞을까요? [2]
5827lee2/18/20233314파이썬 설치 오류 질문입니다 [1]
5826Syong2/14/20233890Socket 관련 Leak (OverlappedAsyncResult, OverlappedData) 관련 문의 [7]파일 다운로드1
5825박성원2/14/20233452Listview 컨트롤의 화면 전환 시 갱신 속도 [1]
5823검은콩2/13/20234022catch(Exception ex)의 line번호를 쉽게 알 수 없는지요? [7]
5822김지우2/11/20233296책을 보면서 sync, async 이해가 되지 않는 부분이 있습니다. [5]파일 다운로드2
5821검은콩2/9/20233323Async 신뢰성과 소켓데이터 [4]
5820차가워2/8/20233449다른 프로세스 실행 후 포커스 가져오기 [3]
5819취준생2/7/20233513WPF 관련 실무가 궁금합니다. [3]
5818윤길2/7/20232953ObservableCollection 에서 INotifyPropertyChanged 구현해야하나요? [2]
5817흰털너부리2/7/20233101배포 시 winform 실행 콘솔로그 보는 방법 [1]
5816흰털너부리2/6/20232923.net core json array validation 질문 드립니다. [1]
5815김재영2/6/20233048종단간 암호화에 대해 시나리오인데 타당한 시나리오일까요? [2]
5814한예지 donator2/6/20233436decompile? [9]
5813김재영2/5/20233275openssl genrsa 2048시 키 생성이 다르게 됩니다. - 파일첨부 [4]파일 다운로드1
5812김재영2/5/20233541openssl genrsa 2048시 키 생성이 다르게 됩니다. [2]
5811치르바2/3/20233378MiniDumpWriteDump API로 덤프수집을 했는데요.. [3]
5810이건우1/31/20233501윈도우서비스를 통한 웹통신관련 질문입니다 [3]
5809이상훈1/31/20233918다채널 영상 디스플레이어 개발 관련 질문입니다. [3]
5808근우1/30/20233596WPF 에서 UserControl 과 ControlTemplate 의 차이점은 무엇인가요? [6]
5807궁금맨1/28/20234728C# 10 책에 나온 예제의 결과가 제 컴에서는 좀 달라서요. 이유가 궁금합니다. [1]
5806스레드1/25/20233307총정리 - 다양한 스레드들 [초안] [1]파일 다운로드1
1  2  3  4  [5]  6  7  8  9  10  11  12  13  14  15  ...