1、在项目自动生成的stdafx.h文件中添加下面头文件

#include <io.h>

#include <fcntl.h>

#include <stdio.h>

 

2、把下面的函数加到你初始化的地方,然后你就可以使用printf函数了

void InitConsoleWindow()

{

    int nCrt = 0;

    FILE* fp;

    AllocConsole();

    nCrt = _open_osfhandle((long)GetStdHandle(STD_OUTPUT_HANDLE), _O_TEXT);

    fp = _fdopen(nCrt, "w");

    *stdout = *fp;

    setvbuf(stdout, NULL, _IONBF, 0);

}

以下红色部分是我初始化函数中添加的

BOOL CSerialPortptestDlg::OnInitDialog()

{

 CDialogEx::OnInitDialog();

  CString str;

 int    Index;

 HKEY   hKey;

 LONG   ret;   

  OSVERSIONINFO     osvi;   

  BOOL   bOsVersionInfoEx;   

 char   keyinfo[100],comm_name[200],ValueName[200];   

 int   i;   

 DWORD   sType,Reserved,cbData,cbValueName;

 // 设置此对话框的图标。当应用程序主窗口不是对话框时,框架将自动

 //  执行此操作

 SetIcon(m_hIcon, TRUE);   // 设置大图标

 SetIcon(m_hIcon, FALSE);  // 设置小图标

 InitConsoleWindow();

 printf( "str   =   %s\n ",   "debug");

调用此函数后会弹出一个CONSOLE,然后printf的东西就会出现在上面。

原地址请见:http://blog.csdn.net/yewenlin/article/details/7658714

【补充】

1,VS可以直接TRACE在IDE上,为什么我们还需要用终端?

如果是在开发环境上,那手段就很多了,是可以很方便的查看问题。

但是如果在目标机上呢?客户的PC端基本上没见过装VS的,那怎么办?

程序写得多了,有时候还是喜欢用这种类似打印的方式来调试和定位错误,这个自己去体会,其实比设置断点什么的有效率得多。

2,这个在VS2013上测试过,也是可以使用的。

3,这个console的方式好就好在,只要初始化一次,在所有的窗口里面都可以直接printf。

4,我还有一个疑问,程序的初始化中,用到了open类的指令和相关指针,不需要close和释放指针操作吗?

这个问题原贴没有涉及,我觉得严谨的话也是应该考虑的。

VC2010 MFC中实现printf调试功能,即MFC程序利用控制台输出调试信息。的更多相关文章

  1. C++ MFC控制台输出调试信息

    1.#include <conio.h> 2.在需要开启控制台窗口的地方调用 AllocConsole();//注意检查返回值 3.在需要输出调试的时候调用_cprintf等函数 如_cp ...

  2. MFC 中的 “printf” 函数

    怀念C语言的我,MFC没法使用的C语言printf函数,于是: int MFCprintf(const char* m_data, ...){ CString str; char printf_buf ...

  3. mfc中Button、Edit Control和MFC EditBrowse Control的用法

    [前(fei)言(hua)] 写LL(1)分析器被CString转string卡了一个多小时也是醉了. 趁着还算清醒写下这次用到的控件的使用方法好了. 这次实验的mfc用到了四个控件:Edit Con ...

  4. MFC程序显示控制台输出

    有的时候,我们用c写的一些东西,可能需要MFC作为UI输入参数进行测试,但是程序里有大量的printf操作,这就需要MFC程序启动的时候同时打开 一个控制台,用于标准输出 查询网络,大致方法有以下两种 ...

  5. Log4j 2.0在开发中的高级使用具体解释—配置简单的控制台输出(三)

    Log4j 2.0在近期迎来了重大的版本号升级.攻克了1.x中死锁bug之外,性能也有10倍的提升. 相同的在最新版本号中的新特性中. 配置文件也不只局限于xml和java特性文件properties ...

  6. VS中为非控制台程序提供控制台输出窗口

    /************************************************************************/ /* 模块名:ConsoleAdapter 文件名 ...

  7. 在MFC中使用Cstring

    此文介绍了关于MFC使用CString的资料,可一参考一下. 转自于VC知识库:http://www.vckbase.com/index.php/wv/829 通过阅读本文你可以学习如何有效地使用 C ...

  8. MFC中使用FLASH

    一.准备工作 第一步:下载并安装Adobe Flash Player. 从官方网站(http://get.adobe.com/cn/flashplayer/)上下载最新的Flash Player(大约 ...

  9. ubuntu安装带调试功能的bochs

    ①进入bochs官网下载源码包 说明 用安装包直接安装没有调试功能 下载源码包步骤 a.输入网址:http://bochs.sourceforge.net/ b.单击图中红色标注图标 c.单击图中红色 ...

随机推荐

  1. LTE Module User Documentation(翻译11)——配置用户测量

    LTE用户文档 (如有不当的地方,欢迎指正!) 17 Configure UE measurements   仿真中激活的用户测量配置取决于所选的 “consumers”,例如切换算法.用户可能需要添 ...

  2. socket初级使用(客户端)

    在国庆这段时间里用零星的一些时间看了一下socket的学习资料,由于笔者偏向学习实用方面的内容,因此此篇文章涉及理论知识较少,主要是以实现思路(怎么做)为主,但在实现之前还是需要了解一些基础的理论知识 ...

  3. zju 1002

    // zju 1002 // #include "stdafx.h" #include <string> #include <iostream> using ...

  4. Hibernate实现向数据库插入一条数据全过程(Study By Example)

    1.数据库(直接在cmd下进入数据库操作亦可) (1)启动Navicat for MySQL (2)打开连接,创建一个数据库,名为testdb (3)新建表user1,表结构如图所示 2.数据库池 ( ...

  5. Mac环境下 配置Python数据分析环境

    采取的思路主要依据的是这一篇文章,连接: http://www.jb51.net/article/78667.htm 但是当安装brew的时候,可能是网站的问题,一直报错 所以从网上查找资料发现,br ...

  6. Visual Studio 如何恢复默认设置

    我们在使用 Visual Studio 的时候,常常有一些窗口不见了又弄不回来的情况,如何恢复默认设置呢? 1.点击“开始-->程序-->Microsoft Visual Studio20 ...

  7. 将FlashPlayerDebugger的trace()功能输出到日志

    1.XP:C:\Documents and Settings\{username} win7:C:\Users\{username} 在以上文件夹下生成mm.cfg文件,写入如下内容: ErrorRe ...

  8. 在FireFox中修改cookie

    一.安装Firebug插件(web开发中常用的调试工具) 1.打开菜单选择[附加组件] 2.搜索firebug,点击安装 3.安装完成    二.cookie的新建与编辑 1.选择cookies标签, ...

  9. 常用的获取时间差的sql语句

    "select count(*) from [注册] where datediff(day,time,getdate())<1";//获取当天注册人员数 sql=" ...

  10. PHP 每天的总结(1)

    今天写博客的心情比以往还要糟糕,因为........................(完结). 1.获取某输入框的值,有两中获取方式,GET和POST .前者  没有为顾客的账户安全着想.而后者返之: ...