我是荔园微风,作为一名在IT界整整25年的老兵,今天来聊聊MFC技术中消息的定义。
本贴子首先介绍MFC消息的基本概念,理解消息的定义是学习使用MFC的基础。了解消息的驱动机制后,才能彻底明白MFC的运行机制。
首先来看什么是消息。通俗地讲,人们常常把外界的各种报道称为消息。消息反映知识状态的改变。而对于计算机语言来说,消息是对象之间进行交互作用和通信的。单一的对象通常没有多大用处。相反,一个对象通常需要跟许多其他对象相互交互才能完成一系列的事件并实现自身价值。
当一辆汽车不被使用时,它就是一堆金属和橡胶,它没有任何的活动。而只有当其他的对象与其交互时,它才可以有所动作。一个MFC程序如果要实现某种功能,就必须要有其他对象与其进行交互或通信。当一个对象希望一个MFC程序执行此对象的方法,此对象就会发送消息给这个MFC程序。在MFC程序设计中,消息是指一个类实例和另一个类实例之间传递的信息。
有时,接收的对象需要更多的信息,这样它才可以正确知道该如何做。比如,当司机想改变汽车的转向,司机就必须为汽车指向应转向哪个方向。此信息是将消息作为参数来传递的。它是由司机传给汽车。
另外,消息提供了两个重要的好处:对象的行为是通过它的方法来表达的,因此消息传递支持所有对象之间的可能的交互,对象不需要在相同的进程或者相同机器上来发送和接收消息给其他的对象。
消息的定义
消息系统对于MFC程序来说十分重要,它相当于一辆汽车的发动机。一个消息,是系统定义的一个32位的值,它唯一地定义了一个事件,向Windows发出一个通知,告诉应用程序某个事情发生了。例如,双击鼠标、改变窗口位置、按下键盘上的一个键都会使Windows发送一个消息给应用程序。
消息本身是作为一系列值传递给应用程序的,其中包括消息的类型以及其他信息。例如,对于按下键盘上的一个键所产生的消息来说,这一系列值中包括了按下键的值。此一系列值的类型叫做MSG,MSG含有 Windows应用程序消息队列的消息信息,它在 Windows中声明如下:
typedef struct tagMsg
{
HWND hwnd; //接受该消息的窗口句柄
UINT message; //消息常量标识符,也就是通常所说的消息号
WPARAM wParam; //32位消息的特定附加信息,确切含义依赖于消息值
LPARAM lParam; //32位消息的特定附加信息,确切含义依赖于消息值
DWORD time; //消息创建时的时间
POINT pt; //消息创建时的光标在屏幕坐标系中的位置
}MSG;
消息可以由系统或者应用程序产生。系统在发生输入事件时产生消息。例如,当用户单击鼠标、敲击键盘或者单击控件,系统也产生消息以响应由应用程序带来的变化。又比如应用程序可以产生消息使窗体执行任务、改变窗口风格、更换贴图等。
针对上面给出的消息MSG,接下来再进一步地解释此结构体中的各个变量。
(1)hwnd表示消息所属的窗口。MFC程序都是窗口应用程序,一个消息一般都是与某个窗口相关联的。例如, 在某个活动窗口中单击鼠标右键, 产生的按键消息就是发给该窗口的。在MFC程序中,用 HWND类型的变量来标识窗口。
(2)message指定了消息的标识符。在Windows中, 消息是由一个数值来表示的,不同的消息对应不同的数值。 但是由于数值不便于记忆,所以 Windows将消息对应的数值定义为WM_XXX宏(WM是Window Message的缩写)的形式,XXX对应某种消息的英文拼写的大写形式。例如,单击鼠标右键消息是 WM_RBUTTON_DOWN,键盘按下消息是WM_KEYDOWN,字符消息是WM CHAR等。在程序中,通常是以WM_XXX宏的形式来使用消息的。
(3)wParam和IParam用于指定消息的附加信息。例如, 当收到一个字符消息时,message成员变量的值就是WM_CHAR, 但用户到底输入的是什么字符,那么就由wParam和lParam来说明。wParam、 lParam表示的信息随 message的值不同而不同。另外在MSDN 中可以发现这两种类型实际上就是unsigned int和 long。
(4) time表示消息投递到消息队列中的时间。
(5)pt表示消息投递到消息队列中光标的当前位置。
注意:如果想知道WM_XXX消息对应的具体数值, 可以在MFC工程中右击WM_XXX,在弹出的菜单中选择Go To Definition, 即可看到该宏的具体定义。跟踪或查看某个变量的定义,都可以使用这个方法。或者是直接在MSDN 中查找。
作者简介:荔园微风,1981年生,高级工程师,浙大工学硕士,软件工程项目主管,做过程序员、软件设计师、系统架构师,早期的Windows程序员,Visual Studio忠实用户,C/C++使用者,是一位在计算机界学习、拼搏、奋斗了25年的老将,经历了UNIX时代、桌面WIN32时代、Web应用时代、云计算时代、手机安卓时代、大数据时代、ICT时代、AI深度学习时代、智能机器时代,我不知道未来还会有什么时代,只记得这一路走来,充满着艰辛与收获,愿同大家一起走下去,充满希望的走下去。