准备知识:
标准C语言预处理要求定义某些对象宏,每个预定义宏的名称一两个下划线字符开头和结尾,这些预定义宏不能被取消定义(#undef)或由编程人员重新定义。
__LINE__ 当前程序行的行号,表示为十进制整型常量
__FILE__ 当前源文件名,表示字符串型常量
另外gcc还支持__func__,和__FUNCTION__,它指示所在的函数,但是这个关键字不被windows下的vc6.0支持
UML类图:
解释;
这些类比较多,必须一点一点的看源码,这里只能简单介绍一下他们之间的关系。Logger类是一个暴露给用户使用的外部类,Logger中包含一个Impl类,Impl类中记录着一条日志的所有信息,包括时间,属性,源文件等信息,Impl类中还包含着一个LogStream类,这个类主要是用来重载<<符号的,LogStream类中包含一个FixedBuffer类,FixedBuffer类是一个缓冲区,记录着日志的内容。Logger类要想将缓冲区里面的内容输出,就需要借助它自身的setOutpyt()函数,用户可以设置这个函数内容,既可以将缓冲区的内容写到标准输出,也可以写到LogFile类中,LogFile类会创建一个日志文件。