Bases du SDK Win32 (11) Explication détaillée de la file d'attente de messages et GetMessage/PeekMessage, SendMessage/Postmesage

黄舟
Libérer: 2017-06-06 10:09:43
original
5644 Les gens l'ont consulté

1. MessageFile d'attente

1.1 File d'attente des messages

La file d'attente des messages est une file d'attente utilisée pour stocker les messages dans la file d'attente. Windows Tous les programmes ont une file d'attente de messages et le programme peut obtenir des messages de la file d'attente.

1.2 Types de files d'attente de messages

File d'attente de messages système : une file d'attente de messages maintenue par le système d'exploitation, qui stocke les messages générés par le système, tels que les messages de la souris et du clavier, etc.

File d'attente des messages du programme : une file d'attente de messages appartenant à chaque application (thread), maintenue par l'application.

Lorsqu'un message de souris, de clavier, etc. est généré, le message est d'abord stocké dans la file d'attente des messages système, puis le système d'exploitation trouve la file d'attente de messages de la fenêtre correspondante en fonction du message stocké et le délivre le message dans la file d'attente des messages de la fenêtre.

1.3 Messages en file d'attente et messages hors file d'attente

Messages en file d'attente : une fois le message envoyé, il est d'abord mis dans la file d'attente puis obtenu via la boucle de messages . Messages courants de la file d'attente : messages du clavier, de la souris, du minuteur , etc.

Message hors file d'attente : Une fois le message envoyé, recherchez directement la fonction de traitement des messages de la fenêtre et appelez la fonction de traitement des messages pour le traitement sans passer par la file d'attente des messages. Messages courants hors file d'attente : WM_PAINT, WM_SIZE, etc.

2. Boucle de message et GetMessage/PeekMessage

2.1 Boucle de message

La boucle de message générale est la suivante :

void Message(HWND hWnd)  
{  
	MSG nMsg = { 0 };
	while (GetMessage(&nMsg, hWnd, 0, 0))  
	{  
		TranslateMessage(&nMsg);  
		DispatchMessage(&nMsg);  

		if(nMsg.message == WM_PAINT)
		{
			char buff[30]={};
			sprintf(buff,"处理消息%d\n",nMsg.message);
			WriteConsole(hOutput,buff,sizeof(buff),NULL,NULL);
		}
	}  
}
Copier après la connexion

GetMessage/PeekMessage : Depuis le programme Récupérez les messages de la file d'attente des messages.

TranslateMessage : traduisez des messages tels que les frappes sur le clavier en messages de caractères.

DispatchMessage : placez à nouveau le message traduit dans la file d'attente des messages du programme.

2.2 GetMessage et PeekMessage

GetMessage(
LPMSG lpMsg,
HWND hWnd,
UINT wMsgFilterMin,
UINT wMsgFilterMax
)
Copier après la connexion

lpMsg : pointeur vers la structure MSG, qui reçoit les informations de message de la file d'attente des messages du fil. hWnd : Le handle de la fenêtre dont le message est obtenu. Lorsque sa valeur est NULL, GetMessage récupère les messages de toute fenêtre appartenant au thread appelant et le message du thread est envoyé au thread appelant via PostThreadMessage.
wMsgFilterMin : Un
entier qui spécifie la valeur minimale du message à récupérer. wMsgFilterMax : Un entier spécifiant la valeur maximale du message à récupérer.
Valeur de retour : Si la fonction obtient d'autres messages autres que WM_QUIT, elle renvoie une valeur non nulle. Si la fonction reçoit un message WM_QUIT, la valeur de retour est zéro. Si une erreur se produit, la valeur de retour est -1. Par exemple, lorsque hWnd est un handle de fenêtre non valide ou que lpMsg est un pointeur non valide. Si vous souhaitez obtenir plus d'
informations sur les erreurs, veuillez appeler la fonction GetLastError.

BOOL PeekMessage(
LPMSG IpMsg,
HWND hWnd,
UINT wMSGfilterMin,
UINT wMsgFilterMax,
UINT wRemoveMsg
);
Copier après la connexion
lpMsg : pointeur de structure MSG pour recevoir les informations du message.

hWnd : Le handle de fenêtre dont le message est vérifié.
wMsgFilterMin : Spécifie le premier message de la plage de messages à vérifier.
wMsgFilterMax : Spécifie le dernier message de la plage de messages à vérifier.
wRemoveMsg : déterminez comment le message est traité. Ce paramètre peut prendre l'une des valeurs suivantes :

Valeur

Signification

PM_NOREMOVE

Une fois PeekMessage traité, le message n'est pas supprimé de la file d'attente.

PM_REMOVE

Une fois le PeekMessage traité, le message est supprimé de la file d'attente.

PM_NOYIELD

Cet indicateur empêche le système de libérer les threads en attendant que le programme appelant devienne inactif. PM_NOYIELD peut être librement combiné en PM_NOREMOVE ou PM_REMOVE.


GetMessage和PeekMessage的主要区别在于:GetMessage是阻塞函数,它会在消息循环中会一直阻塞直到消息队列中出现了消息可以被获取,而PeekMessage是非阻塞函数,不管有没有获取到消息队列中的消息,它都会返回。PeekMessage更多用来检测消息队里中是否有消息,它的最后一个参数可以用来指定获取到消息后要不要把消息从消息队列中移除,通常情况下通过PeekMessage检测到消息队列有消息之后,再调用GetMessage区获取。

2.3 GetMessage/PeekMessage获取消息的过程

1、先在程序的消息队列中查找消息,如果有队列消息,就取出消息。

2、如果程序的消息队列中没有消息,向系统的消息队列获取属于本程序的消息。如果系统的消息队列中有属于本程序的消息,系统的消息队列会将消息分发到本程序的消息队列中。

3、如果系统的消息队列也没有消息,检查窗口需要绘制的区域是否需要重绘,如果发现有需要重绘的区域,产生WM_PAINT消息。

4、如果没有重新绘制区域,检查是否具有到时的定时器,如果有产生WM_TIMER定时器消息。

5、如果没有到时的定时器,整理程序的资源、内存等等。

三、SendMessage和PostMessage

LRESULT SendMessage(
HWND hWnd,
UINT Msg,
WPARAM wParam,
LPARAM IParam
)
Copier après la connexion

hWnd:其窗口程序将接收消息的窗口的句柄。如果此参数为HWND_BROADCAST,则消息将被发送到系统中所有顶层窗口,包括无效或不可见的非自身拥有的窗口、被覆盖的窗口和弹出式窗口,但消息不被发送到子窗口。
Msg:指定被发送的消息。
wParam:指定附加的消息特定信息。
IParam:指定附加的消息特定信息。

返回值:返回值指定消息处理的结果,依赖于所发送的消息。

BOOL WINAPI PostMessage(
HWND hWnd,
UINT Msg,
WPARAM wParam,
LPARAM lParam
);
Copier après la connexion

hWnd:其窗口程序接收消息的窗口的句柄。可取有特定含义的两个值:
HWND_BROADCAST:消息被寄送到系统的所有顶层窗口,包括无效或不可见的非自身拥有的窗口、 被覆盖的窗口和弹出式窗口。消息不被寄送到子窗口
NULL:此函数的操作和调用参数dwThread设置为当前线程的标识符PostThreadMessage函数一样
Msg:指定被寄送的消息。
wParam:指定附加的消息特定的信息。
LParam:指定附加的消息特定的信息。
返回值:如果函数调用成功,返回非零,否则函数调用返回值为零

1、SendMessage

       发送消息到指定的窗口,并等候对方将消息处理,为阻塞函数,获取消息的执行结果后返回。主要需要发送非队列消息,发送的消息不经过消息队列。

2、PostMessage

        发送消息到程序的消息队列,不管消息有没有被处理都会立即返回,用于队列消息的发送

Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

Étiquettes associées:
source:php.cn
Déclaration de ce site Web
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn
Tutoriels populaires
Plus>
Derniers téléchargements
Plus>
effets Web
Code source du site Web
Matériel du site Web
Modèle frontal
À propos de nous Clause de non-responsabilité Sitemap
Site Web PHP chinois:Formation PHP en ligne sur le bien-être public,Aidez les apprenants PHP à grandir rapidement!