设计一个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中。

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



目录
相关文章
|
3月前
|
Java 应用服务中间件 HSF
Java应用结构规范问题之AllLoggers接口获取异常日志的Logger实例的问题如何解决
Java应用结构规范问题之AllLoggers接口获取异常日志的Logger实例的问题如何解决
|
6月前
|
C++
【C++基础】类class
【C++基础】类class
33 1
|
6月前
|
Java 容器
【Java探索之旅】继承结构 继承和组合 protected final
【Java探索之旅】继承结构 继承和组合 protected final
36 0
|
安全 Java 编译器
Java中的String实例化、Annotation注解类、继承的多态和Object类(附带相关面试题)
1.java中String两种实例化对象2.Annotation注解类 3.继承的多态 4.Object类
117 0
Java中的String实例化、Annotation注解类、继承的多态和Object类(附带相关面试题)
|
Python
Python 日志打印之自定义logger handler
Python 日志打印之自定义logger handler
285 0
|
Java
浅谈slf4j,logger中的{}功能
浅谈slf4j,logger中的{}功能
104 0
|
PHP 开发者
最终类 final|学习笔记
快速学习最终类 final,前面说的 PHP 是可以继承的,类是可以继承的,类有我可以继承子类,再往后类又可以继承孙子类,类可以无无限继承,现在确定一个问题,类继承的多了,代表类的重用性增加了,但是系统的解析复杂程度会增加,随之而来的是效率的降低。 那如果有些类已经达到最小的程度,无法再扩展时,或者不需要继续扩展了,这个时候就要使用最终类 final。现在了解一些什么是最终类,掌握 final 关键字的最终作用和实际应用场景。
最终类 final|学习笔记
|
监控 Java API
打印 Logger 日志时,需不需要再封装一下工具类?
在开发过程中,打印日志是必不可少的,因为日志关乎于应用的问题排查、应用监控等。现在打印日志一般都是使用 slf4j,因为使用日志门面,有助于打印方式统一,即使后面更换日志框架,也非常方便。在 《Java 开发手册》中也有相关的规约。
378 0
|
Java
Exception 类的层次
Exception 类的层次
111 0