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.
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.
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.
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); } } }
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.
GetMessage( LPMSG lpMsg, HWND hWnd, UINT wMsgFilterMin, UINT wMsgFilterMax )
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 );
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区获取。
1、先在程序的消息队列中查找消息,如果有队列消息,就取出消息。
2、如果程序的消息队列中没有消息,向系统的消息队列获取属于本程序的消息。如果系统的消息队列中有属于本程序的消息,系统的消息队列会将消息分发到本程序的消息队列中。
3、如果系统的消息队列也没有消息,检查窗口需要绘制的区域是否需要重绘,如果发现有需要重绘的区域,产生WM_PAINT消息。
4、如果没有重新绘制区域,检查是否具有到时的定时器,如果有产生WM_TIMER定时器消息。
5、如果没有到时的定时器,整理程序的资源、内存等等。
LRESULT SendMessage( HWND hWnd, UINT Msg, WPARAM wParam, LPARAM IParam )
hWnd:其窗口程序将接收消息的窗口的句柄。如果此参数为HWND_BROADCAST,则消息将被发送到系统中所有顶层窗口,包括无效或不可见的非自身拥有的窗口、被覆盖的窗口和弹出式窗口,但消息不被发送到子窗口。
Msg:指定被发送的消息。
wParam:指定附加的消息特定信息。
IParam:指定附加的消息特定信息。
返回值:返回值指定消息处理的结果,依赖于所发送的消息。
BOOL WINAPI PostMessage( HWND hWnd, UINT Msg, WPARAM wParam, LPARAM lParam );
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!