您的位置:首页 > 编程语言

Win32编程中如何处理控制台消息

2013-02-03 23:29 399 查看
这篇文章讨论如何处理所有的控制台消息。
  第一步,首先要安装一个事件钩子,也就是说要建立一个回调函数。调用win32 api,原型如下:

bool setconsolectrlhandler(

phandler_routine handlerroutine, // 回调函数

bool add // 表示添加还是删除

);
  参数handlerroutine是一个指向函数的指针,原型如下:

bool winapi handlerroutine(

dword dwctrltype // 控制事件类型

);
  所有的handlerroutine函数只有一个参数dwctrltype,他表示控制台发出了什么消息。参数有下列值:

ctrl_c_event - 当用户按下了ctrl+c,或者由generateconsolectrlevent api发出.

ctrl_break_event - 用户按下ctrl+break, 或者由generateconsolectrlevent api发出.

ctrl_close_event - 当试图关闭控制台程序,系统发送关闭消息。

ctrl_logoff_event - 用户退出时,但是不能决定是哪个用户.

ctrl_shutdown_event - 当系统被关闭时.
  当收到事件的时候,handlerroutine可以选择处理,或者简单的忽略。如果回调函数选择忽略,函数返回false,系统将处理下一个钩子程序。如果处理消息,程序在处理完消息后应该返回true。

ctrl_close_event, ctrl_logoff_event和ctrl_shutdown_event通常被用来处理一些程序的清理工作,然后调用exitprocess api。另外,这三个事件有超时机制,ctrl_close_event是5秒,另外两个是20秒。如果程序超时候,系统将会弹出结束进程的对话框。如果用户选择了结束进程,任何清理工作都不会做,所以应该在超时时间内完成工作。下面是一个回调函数的例子:

bool winapi consolehandler(dword cevent)

{

char mesg[128];

switch(cevent)

{

case ctrl_c_event:

messagebox(null,

"ctrl+c received!","cevent",mb_ok);

break;

case ctrl_break_event:

messagebox(null,

"ctrl+break received!","cevent",mb_ok);

break;

case ctrl_close_event:

messagebox(null,

"program being closed!","cevent",mb_ok);

break;

case ctrl_logoff_event:

messagebox(null,

"user is logging off!","cevent",mb_ok);

break;

case ctrl_shutdown_event:

messagebox(null,

"user is logging off!","cevent",mb_ok);

break;

}

return true;

}

  好,现在已经有了回调函数,再来看看怎么安装钩子:

if (setconsolectrlhandler(

(phandler_routine)consolehandler,true)==false)

{

// unable to install handler...

// display message to the user

printf("unable to install handler!\n");

return -1;

}
  第一个参数是函数指针,就是上面的那个函数。第二个参数是标志,如果为true那么就安装钩子,如果为false那么删除钩子。

  好了,在安装了钩子后,我们就能收到控制台消息了,在程序退出前,要删除钩子。很简单吧。



以上信息与文章正文是不可分割的一部分,如果您要转载本文章,请保留以上信息,谢谢!
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: