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();//释放控制台资源
    后面经过测试发现,如果长时间打印大量字符会造成程序崩溃或者其他不稳定情况出现,所以该调试方面在后期调试和发布版本最好不要用,以免给调试带来不必要的问题。




你可能感兴趣的:(MFC 使用控制台打印程序信息)