QT 学习笔记(1) ---- 打印调试信息

这篇博客探讨了在QT环境中,使用qDebug、std::cout和printf进行输出时的差异。实验显示,qDebug()的输出可能会滞后于std::cout,而printf的输出则会在程序退出时才显示。作者建议在QT开发中优先使用qDebug(),以避免输出顺序混乱的问题。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

QT 中 一般使用的是 qDebug() 对外进行打印的
当然 因为qt的语言是c++ ,所以qt 自然可以使用 std::cout 进行输出,而 C++ 又向下兼容C ,自然也可以使用printf 进行输出的!
这几种打印的输出效果如下: 可以明显的发现 不同的打印糅合到一起使用的时候 打印的顺序出现了问题!!!!!
实验中 只有当窗口完全关闭的时候 printf的数据才打印出来了!
而且debug的数据会部分滞后 cout, 猜测可能是 内部实现上存在缓存,不是立即刷向硬件!
所以实际的开发过程中还是入乡随俗使用 qDebug() 去实现吧。

#include "mainwindow.h"
#include <QApplication>
#include <QWidget>
#include <QDialog>
#include <QDebug>
#include <iostream>
#include <stdio.h>
int main(int argc, char *argv[])
{
    QApplication a(argc, argv);

    MainWindow w;

    qDebug() << "qDebug() message 1";
    qDebug() << "qDebug() message 2";
    qDebug() << "qDebug() message 3";
    qDebug() << "qDebug() message 4";
    qDebug() << "qDebug() message 5";
    qDebug() << "qDebug() message 6";
    qDebug() << "qDebug() message 7";
    qDebug() << "qDebug() message 8";
    std::cout<< "std::cout message 1" << std::endl;
    std::cout<< "std::cout message 2" << std::endl;
    std::cout<< "std::cout message 3" << std::endl;
    std::cout<< "std::cout message 4" << std::endl;
    std::cout<< "std::cout message 5" << std::endl;
    std::cout<< "std::cout message 6" << std::endl;
    std::cout<< "std::cout message 7" << std::endl;
    std::cout<< "std::cout message 8" << std::endl;
    printf("printf message 1\n");
    printf("printf message 2\n");
    printf("printf message 3\n");
    printf("printf message 4\n");
    printf("printf message 5\n");
    printf("printf message 6\n");
    printf("printf message 7\n");
    printf("printf message 8\n");
    w.show();

    return a.exec();
}


Starting F:\xxxxxx.exe...
qDebug() message 1
std::cout message 1
std::cout message 2
std::cout message 3
std::cout message 4
std::cout message 5
std::cout message 6
std::cout message 7
std::cout message 8
qDebug() message 2
qDebug() message 3
qDebug() message 4
qDebug() message 5
qDebug() message 6
qDebug() message 7
qDebug() message 8
printf message 1
printf message 2
printf message 3
printf message 4
printf message 5
printf message 6
printf message 7
printf message 8
xxxxxxxxxx.exe exited with code 0
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值