Qt QDebug等重定向到文件中
源地址:http://blog.163.com/soyo_gogogo/blog/static/171414077201392705639321/
Qt的qDebug() 等函数,可以打印出十分细致的log,用过你就会喜欢。现在要将qDebug() 等重定向到文件中。
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等重定向到文件中的更多相关文章
- Linux下执行的java命令重定向到文件中的方法
在Linux下通常会执行如:java -version 的命令, 但是,命令只是打印到了屏幕上不能重定向到文件中或标准输出流中. 此时需要将错误输出流重定向到标准输出流中就可以得到了. 比如:java ...
- [Linux应用]Linux应用程序输出数据重定向到文件中
转自:http://blog.chinaunix.net/uid-20680966-id-4698387.html 目的是要让程序的printf的打印能重定向到某个文本中,ctrl+c强制退出后查看文 ...
- C0301 代码块{}的使用,重定向, 从文件中读取行
#!/bin/bash # 从 /etc/fstab 中读行 File=/etc/fstab { read line1 read line2 } < $File # {}代码块, ...
- Linux 重定向输出到多个文件中
转自:http://codingstandards.iteye.com/blog/833695 用途说明 在执行Linux命令时,我们可以把输出重定向到文件中,比如 ls >a.txt,这时我们 ...
- php 执行结果可以直接重定向文件中
将php中的echo输出到shell上的结果,重定向到文件中. php script.php >result.txt;
- 从键盘或文件中获取标准输入:read命令
文件的描述符和重定向 文件描述符是和文件的输入.输出相关联的非负整数,Linux内核(kernel)利用文件描述符(file descriptor)来访问文件.打开现存文件或新建文件时,内核会返回一个 ...
- 如何将top命令输出重定向为文件
命令: # top -b -n 2 -d 3 > /tmp/top.out 解析: -b: batch 模式,可以重定向到文件中 -n:一共取2次top数据 -d:每次top数据间隔为3秒
- C0302 将一个代码块中的内容保存在文件中, 查看一个rpm包是否可以安装
#!/bin/bash # 这个脚本是用来描述和确认是否可以安装一个rpm包 # 在一个文件中保存输出 SUCCESS=0 E_NOARGS=65 if [ -z "$1" ] t ...
- 《Java虚拟机原理图解》1.3、class文件中的访问标志、类索引、父类索引、接口索引集合
讲完了class文件中的常量池,我们就相当于克服了class文件中最麻烦的模块了.现在,我们来看一下class文件中紧接着常量池后面的几个东西:访问标志.类索引.父类索引.接口索引集合. 1. 访问标 ...
随机推荐
- [置顶] 我的GB28181标准开发里程碑——基于eXosip的IPC端与SPVMN注册成功
昨天编译搭建好eXosip的开发环境后,今天完成了SIP注册功能,里程碑一战啊!加油加油,成功就在眼前! 今天基于eXosip做了一个IPC客户端,成功与公安部的SPVMN视频监控联网调测软件自测工具 ...
- ThinkPHP - URL生成(U函数)
效果: 代码: //U('[分组/模块/操作]?参数' [,'参数','伪静态后缀','是否跳转','显示域名']) echo U('Index/index', array(), '.html', 0 ...
- eclipse+python+Anaconda ML环境搭建
整个流程按照这个来: http://blog.csdn.net/olaking/article/details/42435451 你会发现pydev安装不了,听说服务器被和谐了,下面这篇文章告诉你如何 ...
- grub2的/etc/default/grub文件详解
# If you change this file, run 'update-grub' afterwards to update# /boot/grub/grub.cfg.GRUB_DEFAULT= ...
- [Swust OJ 179]--火柴棍(找规律)
题目链接:http://acm.swust.edu.cn/problem/0179/ Time limit(ms): 1000 Memory limit(kb): 65535 Descriptio ...
- 复习C语言系列二:动态调用函数指针数组
a:用call_fun_ptr调用afun(),b:用call_fun_ptr调用bfun() a 请输入给您指定的函数输调用的参数 afun_par ------------------------ ...
- iOS 常用开源代码整理
本文章不定期整理. 1.AFNetworking AFNetworking 采用 NSURLConnection + NSOperation, 主要方便与服务端 API 进行数据交换, 操作简单, 功 ...
- java面向对象中的String类中12种常用的方法
1.字符串与字符数组的转换 字符串可以使用toCharArray()方法变成一个字符数组,也可以使用String类的构造方法把一个字符数组变成一个字符串. public class StringAPI ...
- bash有空格的文件名
http://www.keakon.net/2011/10/20/bash%E4%B8%8B%E5%A4%84%E7%90%86%E5%8C%85%E5%90%AB%E7%A9%BA%E6%A0%BC ...
- 什么时候需要交换Top Level ?
什么时候需要交换Top Level ? 上一篇中提到,如果采用仿真的时候,运用门级仿真就需要进行顶层交换,RTL仿真不需要,那么什么时候需要呢? QuartusII 向下包含,在Project Nav ...