MFC 使用控制台打印程序信息

在MFC编程中,代码的调试一直是比较悲剧的事情。通常是搞一个 MessageBox 来打印信息查看程序是否执行或执行是否有误,又或者是在程序中设断点来实现。这两种方法在需要获得多个信息的情况下皆不方便。此外,MessageBox 在涉及到打印非 CString 格式的信息时还要用 CString 的 Format 函数进行格式转换,又给调试带来进一步的麻烦。综上,在MFC程序的调试阶段加入像WIN32控制台程序那样的控制台来打印程序信息显得直观又方便易用。下面,是在MFC程序中添加控制台程序的方法:


在对话框程序的初始化函数OnInitDialog()中(如果不是对话框程序,或者希望在子对话框中加入,只需将代码添加到相应的入口位置即可)加入如下代码:


::AllocConsole();//打开控件台资源
FILE *fp;
freopen_s(&fp,"CONOUT$", "w+t", stdout);//申请写,这个是针对VS2013版本的代码,在VS较为早期的版本比如VS2008中,可将freopen_s改为freopen,并将参数改为对应形式即可


到此,程序在运行时就会打开一个控制台窗口等待输入,只要在程序中加入 printf(",,,,,,")  则可在控制台中打印出信息。

最后,要记得在程序关闭的地方调用如下函数关闭掉控制台程序,不然会导致程序无法正常关闭的悲剧。

本人是在对话框程序的 WM_CLOSE 消息响应函数中添加的:


FreeConsole();//释放控制台资源





posted @ 2014-05-03 13:33  weixinhum  阅读(819)  评论(0编辑  收藏  举报