当前位置: 首页 > 图文教程 > 开发语言 > VC++ > VC++:VC++中Windows 3.x的协同多任务

VC++
关于内联汇编的几个技巧
const使用详解
为什么要在operator=中返回*this的引用
如何在派生类中的隐藏基类的虚拟重载函数?
C++指针使用方法解惑
如何用编程获取CD-ROM的驱动器盘符?
声明函数指针并实现回调
定义函数对象
在名字空间中声明类和成员函数
自制性能测试类
为什么operator=操作符返回引用
单实例设计模式的实现
初始化类对象
C++编程杂谈之三:面向对象(续)
C++编程杂谈之二:面向对象
C++编程杂谈之一:编译器
解析动态联编(上篇) - 作者:tingya
解析动态联编(下篇) - 作者:tingya
创建和访问环境变量
在预先定义的内存位置构造一个对象

VC++:VC++中Windows 3.x的协同多任务


出处:互联网   整理: 软晨网(RuanChen.com)   发布: 2009-12-26   浏览: 201 ::
收藏到网摘: n/a

16位的Windows 3.x中,应用程序具有对CPU的控制权。只有在调用了GetMessagePeekMessageWaitMessageYield后,程序才有可能把CPU控制权交给系统,系统再把控制权转交给别的应用程序。如果应用程序在长时间内无法调用上述四个函数之一,那么程序就一直独占CPU,系统会被挂起而无法接受用户的输入。

 

  因此,在设计16位的应用程序时,程序员必须合理地设计消息处理函数,以使程序能够尽快返回到消息循环中。如果程序需要进行费时的操作,那么必须保证程序在进行操作时能周期性的调用上述四个函数中的一个。

 

  在Windows 3.x环境下,要想设计一个既能执行实时的后台工作(如对通信端口的实时监测和读写),又能保证所有界面响应用户输入的单独的应用程序几乎是不可能的。

 

 

  折衷的办法是在执行长期工作时弹出一个非模态对话框并禁止主窗口,在消息循环内分批执行后台操作。对话框中可以显示工作的进度,也可以包含一个取消按钮以让用户有机会中断一个长期的工作。典型的代码如下。这样做既可以保证工作实时进行,又可以使程序能有限地响应用户输入,但此时程序实际上已不能再为用户干别的事情了。

 

在协同多任务环境下防止程序被挂起的一种方法

 

bAbort=FALSE;

 

lpMyDlgProc=MakeProcInstance(MyDlgProc, hInst);

 

hMyDlg=CreateDialog(hInst, Abort, hwnd, lpMyDlgProc); //创建一个非模态对话框

 

ShowWindow(hMyDlg, SW_NORMAL);

 

UpdateWindow(hMyDlg);

 

EnableWindow(hwnd, FALSE); //禁止主窗口

 

. . .

 

while(!bAbort)

 

{

 

. . . //执行一次后台操作

 

. . .

 

while(PeekMessage(&msg, NULL, NULL, NULL, PM_REMOVE))

 

{

 

if(!IsDialogMessage(hMyDlg, &msg))

 

{

 

TranslateMessage(&msg);

 

DispatchMessage(&msg);

 

}

 

}

 

}

 

EnableWindow(hwnd, TRUE); //允许主窗口

 

DestroyWindow(hMyDlg);

 

FreeProcInstance(lpMyDlgProc);