设计一个Logger类

简介:

需求:想要实现一个Logger可以以以下方式使用:


Logger log("2013-03-05.log");
log << "This is a logger test" << endl;
log << "value of Temp = " << temp << endl;
log << "Array[" << index << "] = " << array[index] << endl;

实现有一点类似cout。

下面是我定义Logger类:  


class Logger
{
public:
    Logger(const QString& logfilename);
    void sync(void);  // 将m_logStr写入log文件
 
    Logger& operator << (QString str) { m_logStr += str; return (*this); }    
    Logger& operator << (int t) { m_logStr += t; return (*this); }
    // Other operators, QChar, const char*, unsigned int, etc
    // ...
 
    Logger& operator << ( Logger& (*op) (Logger&) ) { return (*op)(*this); }
 
private:
    QString m_logStr;
}
 
static Logger& endl (Logger &log) { log.sync(); return log; }

如何用<<连接大家应该都很容易理解,关键技术点在这个endl。
其中最后一个 operator << 重载告诉编译器:如果<<后面是一个(Logger&)(*op)(Logger&)的函数指针,那么就这么调用它:(*op)(*this)

然后在全局中实现了Logger& endl(Logger&)的函数。当log << endl 时,就会调用这个endl函数并执行。
就这样,我何可以定义很多类似的流符号了。

那个可不可以这样呢? 


log << size(1024) << "Set size ..." << endl;

我们需要可以像上面size()可以带参的,怎么实现? 


struct size{
    size(int d): value(d){}
    int data;
};
 
class Logger
{
public:
    // Other ...
    Logger& operator << ( size v ) { m_nSize = v.data; return (*this); }
 
private:
    int m_nSize;
}

定义结构体size,并指定其构造函数size(int value)。所以"log << size(1024)"中的"size(1024)"其实是在构造一个size结构类型的变量,而1024就被存到了size::nSize中。

这就是我今天的收获!谢谢观看~~



目录
相关文章
|
26天前
|
Java 应用服务中间件 HSF
Java应用结构规范问题之AllLoggers接口获取异常日志的Logger实例的问题如何解决
Java应用结构规范问题之AllLoggers接口获取异常日志的Logger实例的问题如何解决
|
1月前
|
Java API 开发工具
日志记录当前类和当前方法
公司原有日志记录需手动输入类名与方法名,繁琐且易错。目标是开发工具类简化此过程。调研发现`Thread.currentThread().getStackTrace()`可获取调用栈信息,0号索引为该方法自身。在被调用的方法内,可通过访问1号索引获取所在类及方法名。为此,创建`CurClassAndMethodUtil`工具类,其`getCurClazzAndMethod`方法返回调用者的类名与方法名,解决手动输入问题。实际应用中,因多一层工具方法调用,需访问2号索引。最终实现自动化获取记录信息,提高效率。
|
4月前
|
Java 容器
【Java探索之旅】继承结构 继承和组合 protected final
【Java探索之旅】继承结构 继承和组合 protected final
31 0
最通俗易懂的 JAVA slf4j,log4j,log4j2,logback 关系与区别以及完整集成案例
最通俗易懂的 JAVA slf4j,log4j,log4j2,logback 关系与区别以及完整集成案例
最通俗易懂的 JAVA slf4j,log4j,log4j2,logback 关系与区别以及完整集成案例
|
Java
Java 反射四大核心类:Class、Constructor、Method、 Filed
Java 反射四大核心类:Class、Constructor、Method、 Filed
126 0
|
Python
Python 日志打印之自定义logger handler
Python 日志打印之自定义logger handler
267 0
|
Java
浅谈slf4j,logger中的{}功能
浅谈slf4j,logger中的{}功能
97 0
|
SQL Java 数据库连接
java使用slf4j+log4j进行日志记录并将ERROR级别信息入库
%d{yyyy-MM-dd HH:mm:ss}表示日志信息产生的时间,{yyyy-MM-dd HH:mm:ss}表示一种时间格式,你也可以直接写成%d;
428 0
java使用slf4j+log4j进行日志记录并将ERROR级别信息入库
|
监控 Java API
打印 Logger 日志时,需不需要再封装一下工具类?
在开发过程中,打印日志是必不可少的,因为日志关乎于应用的问题排查、应用监控等。现在打印日志一般都是使用 slf4j,因为使用日志门面,有助于打印方式统一,即使后面更换日志框架,也非常方便。在 《Java 开发手册》中也有相关的规约。
358 0
|
Java
Exception 类的层次
Exception 类的层次
98 0