Chinaunix首页 | 论坛 | 博客
  • 博客访问: 1427215
  • 博文数量: 430
  • 博客积分: 9995
  • 博客等级: 中将
  • 技术积分: 4388
  • 用 户 组: 普通用户
  • 注册时间: 2006-05-24 18:04
文章存档

2013年(1)

2008年(2)

2007年(14)

2006年(413)

分类:

2006-06-02 09:06:07

1.事件驱动程序
要实现这种Windows的多任务工作方式,过程式编程方式显然是不适合的。于是就产生了适应于这种工作方式的编程模式:事件驱动编程方式。
事件驱动程序以窗口为中心,根据用户的不同操作激活处理相应事件的代码并完成相应的任务。
事件驱动的程序设计是一种“被动”式程序设计方法,程序开始运行时,处于等待用户输入事件状态,然后取得事件并作出相应反应,处理完毕又返回并处于等待事件状态。

2.消息
消息是报告有关事件发生的通知。
在Windows系统中,消息是一种Windows数据结构,其中包含有消息的名字、消息发生时的一些参数,以及处理这个消息的函数指针。
用户操作——〉触发事件——〉通过消息的方式通知Windows系统
应用程序获得某个消息——〉调用消息处理函数处理消息
根据消息来源的不同,消息可分为以下4类:
(1)输入消息
(2)控制消息
(3)系统消息
(4)用户消息

解读Win32应用程序
在最简单的Win32程序中,一共有5个全局函数和3个全局变量。

1.句柄
句柄是用来唯一标示某个对象的长整数,可以简单把句柄理解为指针,但实际上还不太一样。Windows系统定义了很多句柄,如窗口句柄、设备环境句柄等等,在MFC中都被封装起来了,因此一般看不到。但还有许多MFC中的函数沿用API的习惯,使用句柄作为函数的参数。如果使用 API编程就得经常跟句柄打交道了。

2.Windows程序的入口点——WinMain函数
WinMain函数主要执行了两个动作:一是产生几乎每个Windows程序都需要的主窗口界面;二是建立Windows程序的心脏:消息循环。

分析代码:
int APIENTRY _tWinMain(HINSTANCE hInstance,
                     HINSTANCE hPrevInstance,
                     LPTSTR    lpCmdLine,
                     int       nCmdShow)
{
 MSG msg; //定义一个Windows的消息结构

 // 初始化全局字符串
 MyRegisterClass(hInstance);  //首先调用此函数注册一个窗口类

 // 执行应用程序初始化:
 if (!InitInstance (hInstance, nCmdShow)) //在此函数中,就产生了主窗口界面。
 {
  return FALSE;  //如果产生主窗口不成功,程序直接返回,退出
 }

 //以上是WinMain()函数的第一项工作:产生主窗口。
 //下面是WinMain()函数的第二项工作:建立主消息循环。
 //下面这个循环就是Windows程序的心脏:主消息循环。一旦退出主消息循环,程序就结束了。

 // 主消息循环:
 while (GetMessage(&msg, NULL, 0, 0)) //使用GetMessage函数从消息队列中获取消息;
 {
  if (!TranslateAccelerator(msg.hwnd, hAccelTable, &msg)) //解释加速键
  {
   TranslateMessage(&msg); //使用TranslateMessage函数解释消息;
   DispatchMessage(&msg); //发送消息到主窗口函数中去。
  }
 }
 //退出消息循环,WinMain函数才返回,程序才结束。
 return (int) msg.wParam;
}

3.消息队列
消息队列是系统用来存放各种消息的地方,Windows操作系统有一个消息队列,各个应用程序也有自己的消息队列。上面的GetMessage函数就是从这两个消息队列中获取消息,当获取到了一个退出消息的时候,消息循环就终止了,程序也就相应的结束了。

阅读(378) | 评论(0) | 转发(0) |
0

上一篇:MIPS

下一篇: Linux bootloader 编写方法

给主人留下些什么吧!~~