源地址:http://blog.163.com/soyo_gogogo/blog/static/171414077201392705639321/

Qt的qDebug() 等函数,可以打印出十分细致的log,用过你就会喜欢。现在要将qDebug() 等重定向到文件中。

        
使用Qt的MessageHandler可以将消息重定向。在Qt4.x时代,安装一个消息处理器是用

qInstallMsgHandler

来安装的。这个函数接受的一个函数指针作为参数,函数的定义是

void funName(QtMsgType , const char *)

如笔者的一个小函数:

void messageOutput(QtMsgType, const char *msg)
{
    static QMutex mutex;
    mutex.lock();
    logFile->write(msg);
    logFile->write("\n");
    logFile->flush();
    mutex.unlock();
}
 
// Install it
qInstallMsgHandler(messageOutput);

logFile是一个全局的QFile类指针。

今天笔者使用Qt5.1版本来编写程序。该函数编译不通过。因为Qt 5.x后,这个函数被

qInstallMessageHandler

替代了。这个函数同样接受一个函数指针作为参数,函数的定义是

void funName(QtMsgType , QMessageLogContext , const QString &)

可见,该函数中多了一个QMessageLogContext参数。这个参数包含了debug的一些基本信息,例如该debug所在的函数,所在的文件,所在的行数等。可以让debug更加详细。

笔者的一段小代码

void MessageOutput(QtMsgType type , const QMessageLogContext &context , const QString &msg)
{
    static QMutex mutex;
    mutex.lock();
 
    QString log;
    switch(type)
    {
    case QtDebugMsg:
        log = QString("Debug: ");
        break;
    case QtWarningMsg:
        log = QString("Error: ");
        break;
    case QtCriticalMsg:
        log = QString("Critical Error: ");
        break;
    case QtFatalMsg:
        log = QString("Fatal Error: ");
        abort();
        break;
    default:
        log = QString("Unknow Msg Type : ");
        break;
    };
    log += QTime::currentTime().toString("hh:mm:ss.zzz, File: ") + QString(context.file) ;
    log += QString(", Line: " ) + QString::number(context.line) + QString(" : %1\n").arg(msg);
    logFile->write(log.toStdString().c_str());
    logFile->flush();
    mutex.unlock();
}

可以见到在最后面做了一些格式化的东西。这样,debug看起来就是这样的

 

至于重定向到哪里,就看你的QFile打开的是哪个文件了。

这样处理格式其实还不是那么优雅。像第一个函数那样,没有做任何格式化的操作,因为笔者在另外一个文件中做了格式化。

这个文件被命名为log.h。这样,需要用到QDebug的地方,都可以#include"log.h"。

相信大家都明白了。

Enjoy your Qt.

Qt QDebug等重定向到文件中的更多相关文章

  1. Linux下执行的java命令重定向到文件中的方法

    在Linux下通常会执行如:java -version 的命令, 但是,命令只是打印到了屏幕上不能重定向到文件中或标准输出流中. 此时需要将错误输出流重定向到标准输出流中就可以得到了. 比如:java ...

  2. [Linux应用]Linux应用程序输出数据重定向到文件中

    转自:http://blog.chinaunix.net/uid-20680966-id-4698387.html 目的是要让程序的printf的打印能重定向到某个文本中,ctrl+c强制退出后查看文 ...

  3. C0301 代码块{}的使用,重定向, 从文件中读取行

    #!/bin/bash # 从 /etc/fstab 中读行 File=/etc/fstab {     read line1     read line2 } < $File # {}代码块, ...

  4. Linux 重定向输出到多个文件中

    转自:http://codingstandards.iteye.com/blog/833695 用途说明 在执行Linux命令时,我们可以把输出重定向到文件中,比如 ls >a.txt,这时我们 ...

  5. php 执行结果可以直接重定向文件中

    将php中的echo输出到shell上的结果,重定向到文件中. php script.php >result.txt;

  6. 从键盘或文件中获取标准输入:read命令

    文件的描述符和重定向 文件描述符是和文件的输入.输出相关联的非负整数,Linux内核(kernel)利用文件描述符(file descriptor)来访问文件.打开现存文件或新建文件时,内核会返回一个 ...

  7. 如何将top命令输出重定向为文件

    命令: # top -b -n 2 -d 3 > /tmp/top.out 解析: -b: batch 模式,可以重定向到文件中 -n:一共取2次top数据 -d:每次top数据间隔为3秒

  8. C0302 将一个代码块中的内容保存在文件中, 查看一个rpm包是否可以安装

    #!/bin/bash # 这个脚本是用来描述和确认是否可以安装一个rpm包 # 在一个文件中保存输出 SUCCESS=0 E_NOARGS=65 if [ -z "$1" ] t ...

  9. 《Java虚拟机原理图解》1.3、class文件中的访问标志、类索引、父类索引、接口索引集合

    讲完了class文件中的常量池,我们就相当于克服了class文件中最麻烦的模块了.现在,我们来看一下class文件中紧接着常量池后面的几个东西:访问标志.类索引.父类索引.接口索引集合. 1. 访问标 ...

随机推荐

  1. 【甘道夫】使用HIVE SQL实现推荐系统数据补全

    需求 在推荐系统场景中,假设基础行为数据太少,或者过于稀疏,通过推荐算法计算得出的推荐结果非常可能达不到要求的数量. 比方,希望针对每一个item或user推荐20个item,可是通过计算仅仅得到8个 ...

  2. 【QT相关】类头文件解读、QT编辑模式、读取text文本

    Wizard产生的头文件类包含了必须的#include文件.构造函数.析构函数和UI对象: #include <QMainWindow> namespace Ui {class Notep ...

  3. Java字节码中的方法调用

    invokestatic,用于static修饰的方法.任何时候调用的时候只需要类名+方法名即可,无需new.JVM直接将其映射到方法区,执行速度极快.当该方法需要参数的时候,invokestatic会 ...

  4. ThinkPHP 3.1.2 URL<1>

    # # ThinkPHP 3.1.2 URL 本节课大纲: 一.URL规则 1.默认是区分大小写的 2.如果我们不想区分大小写可以改配置文件 'URL_CASE_INSENSITIVE'=>tr ...

  5. 基于visual Studio2013解决C语言竞赛题之0522和为素

     题目

  6. 利用cmake来搭建开发环境

    对于经常在终端下写程序的non-windows程序员,Makefile绝对是最常用的工具,小到一个文件的简单的测试程序,大到数百个文件的商业软件,只需要有shell,一个make命令就可得到可运行的程 ...

  7. 如何A掉未来程序改

    话说有这样一道神题:[集训队互测2015]未来程序·改. 大意是要求写一个简单的C++解释器!这里去掉了C++的许多特性,连简单的break和continue都没有了! 话说NOI被屠了之后,一时心血 ...

  8. zoj 2277 The Gate to Freedom

    N^N = X --->    Nlog10(N) = log10( X ) ---->    X的最高位为 Nlog10(N) 小数部分的第一个非0位 #include<stdio ...

  9. libgdx, mouse 关节

    鼠标与body的交互就靠这个mouse 关节了. 在使用中:主要分成3步: 步1:mouseDown : 这个时期,调用world->QueryAABB.它有一个回调接口,并依据鼠标指针指定一个 ...

  10. netbeans 将项目打包生成单个可执行的 jar

    原文:netbeans 打包生成 jar 文件页里找到build.xml文件,打开在</project>前 加入以下代码保存之 <target name="package- ...