博客
关于我
MFC学习——MFC工程在调试中查看输出信息
阅读量:543 次
发布时间:2019-03-09

本文共 1127 字,大约阅读时间需要 3 分钟。

简介:

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

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

功能:

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

方法汇总

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

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

    需要注意:

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

2、只有在DEBUG版本调试时才会有输出,如果是在

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

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

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

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

fprinf()函数,可以将需要输出的信息存放在自定义的文件中。

用法:

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函数的打印信息

附录:

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

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

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

你可能感兴趣的文章
Nacos做注册中心使用
查看>>
Nacos做配置中心使用
查看>>
Nacos原理
查看>>
Nacos发布0.5.0版本,轻松玩转动态 DNS 服务
查看>>
Nacos启动异常
查看>>
Nacos和Zookeeper对比
查看>>
Nacos在双击startup.cmd启动时提示:Unable to start embedded Tomcat
查看>>
Nacos如何实现Raft算法与Raft协议原理详解
查看>>
Nacos安装教程(非常详细)从零基础入门到精通,看完这一篇就够了
查看>>
Nacos实战攻略:从入门到精通,全面掌握服务治理与配置管理!(下)
查看>>
Nacos心跳机制实现快速上下线
查看>>
Nacos服务注册与发现demo
查看>>
Nacos服务注册总流程(源码分析)
查看>>
nacos服务注册流程
查看>>
Nacos服务部署安装
查看>>
nacos本地可以,上服务器报错
查看>>
Nacos注册中心有几种调用方式?
查看>>
nacos注册失败,Feign调用失败,feign无法注入成我们的bean对象
查看>>
nacos源码 nacos注册中心1.4.x 源码 nacos源码如何下载 nacos 客户端源码下载地址 nacos discovery下载地址(一)
查看>>
nacos源码 nacos注册中心1.4.x 源码 spring cloud alibaba 的discovery做了什么 nacos客户端是如何启动的(二)
查看>>