MFC学习——MFC工程在调试中查看输出信息

简介:

MFC工程,通常状况下,不支持常规的cout、printf 等输出函数,即不能经过此类方法在控制台查看输出信息。函数

但为了方便调试和获取重要信息,不得不利用某些方法来实现数据的输出和显示,因此汇总以下方法,供你们使用spa


功能:

  在调试MFC程序时,查看特定位置变量的输出值;或者在某特定条件执行时,给出一个输出标识。.net


方法汇总


方法一:调用TRACE(LPCTSTR lpszFormat, ...)函数


在MFC中使用TRACE函数来打印输出结果倒是很是方便,和在控制台程序中使用cout、printf函数的使用方法和效果相似。不过有几点  调试

    须要注意:orm

一、TRACE函数的输出是在Output窗口的Debug选项下; blog

二、只有在DEBUG版本调试时才会有输出,若是是在it

        三、 Release版本调试或者运行程序时,将不会看到输出。io


方法二:使用AfxMessageBox( )函数来输出信息


AfxMessageBox()函数在调试时也比较经常使用,使用方法简单,此处就不作介绍。变量


方法三:使用fprinf()函数来输出信息

fprinf()函数,能够将须要输出的信息存放在自定义的文件中。bug

用法:

FILE *gFp = fopen("gFp.txt","w+");

fprintf("Hello , the world !");

但该函数使用,缺点比较明显:程序必须能够正常运行,即程序运行完以后,才能够生成并查看输出信息


方法四:将标准输出定向到本身建立的控制台

      #include "io.h"
      #include "fcntl.h"

        void InitConsole()
      {
            int nRet= 0;
           FILE* fp;
           AllocConsole();
           nRet= _open_osfhandle((long)GetStdHandle(STD_OUTPUT_HANDLE), _O_TEXT);
           fp = _fdopen(nRet, "w");
          *stdout = *fp;
          setvbuf(stdout, NULL, _IONBF, 0);
    }

  将此函数在MFC程序初始化的地方调用,便可使用控制台查看printf函数的打印信息


附录:

一、VC调试的方法汇总http://blog.csdn.net/chocolateconanlan/article/details/4061545

二、参考连接一:http://blog.csdn.net/brucezong/article/details/6889974

三、参考连接二:http://blog.csdn.net/liuxizhen2009/article/details/8557888