阅读log4cplus源代码过程中的小知识点整理
2013-05-29 15:46
169 查看
开始阅读log4cplus源代码,这个库规模不大,但作者的C++功底不错(至少我个人认为),而且更新的相当频繁,作为学习C++的实际分析对象不错。log4cplus源代码中用到了Singleton、Factory Method、Bridge、Observer等等Pattern,还有Pimpl机制、引用计数机制等等,非常值得总结学习。不过,这篇文章,主要用来记录,阅读代码过程中的C++小知识点,偶有所得,都会持续更新,也希望得到有缘进来的朋友的留言指正,先谢啦。
2012.10.9记录 源代码中大量出现这样的宏定义
理解起来并不难,主要是为了Unicode下,字符串前需要L,转换为WCHAR。在宏定义中可以用##运算符把前后两个预处理Token连接成一个预处理Token。假如我们define了UNICODE这个宏,那么LOG4CPLUS_TEXT("Second"),也就相当于L"Second";否则,就等于"Second"。问题是,为什么要多加一层宏定义,直接像下面不可以吗?
原因就在于,凡宏定义里有用'#'或'##'的地方宏参数是不会再次展开的。假如我们没有使用作者的代码中的中间转换宏,遇到类似下面这样的宏展开就会得到不是期望的结果。
当我们遇到LOG4CPLUS_TEXT(MYSTRING),就会展开成LMYSTRING,而不是我们期望的L"MYLOG"。加一个中间转换宏,就是为了要让宏参数完全展开。
2012.10.9记录 源代码中大量出现这样的宏定义
#ifdef UNICODE # define LOG4CPLUS_TEXT2(STRING) L##STRING #else # define LOG4CPLUS_TEXT2(STRING) STRING #endif // UNICODE #define LOG4CPLUS_TEXT(STRING) LOG4CPLUS_TEXT2(STRING)
理解起来并不难,主要是为了Unicode下,字符串前需要L,转换为WCHAR。在宏定义中可以用##运算符把前后两个预处理Token连接成一个预处理Token。假如我们define了UNICODE这个宏,那么LOG4CPLUS_TEXT("Second"),也就相当于L"Second";否则,就等于"Second"。问题是,为什么要多加一层宏定义,直接像下面不可以吗?
#define LOG4CPLUS_TEXT(STRING) L##STRING
原因就在于,凡宏定义里有用'#'或'##'的地方宏参数是不会再次展开的。假如我们没有使用作者的代码中的中间转换宏,遇到类似下面这样的宏展开就会得到不是期望的结果。
#define LOG4CPLUS_TEXT(STRING) L##STRING
#define MYSTRING "MYLOG"
当我们遇到LOG4CPLUS_TEXT(MYSTRING),就会展开成LMYSTRING,而不是我们期望的L"MYLOG"。加一个中间转换宏,就是为了要让宏参数完全展开。
相关文章推荐
- 阅读log4cplus源代码过程中的小知识点整理(持续更新)
- 工作过程中阅读的书籍整理
- 简练软考知识点整理-控制进度管理过程
- 一些我面试过程中遇到j2ee知识点的整理,答案来源于网络
- 一些我面试过程中遇到j2ee知识点的整理(2),答案来源于网络
- 简练软考知识点整理-制定预算过程
- 简练软考知识点整理-规划成本管理过程
- 一部章回小说从网上下载到离线阅读的整理过程
- 简练软考知识点整理-估算成本过程
- 简练软考知识点整理-项目管理过程与过程组
- img robertcpp Android热补丁技术方案整理 发表于2016/6/29 12:06:54 7881人阅读 分类: android 概述 项目快速迭代过程中,
- mongoose源码阅读过程中的小知识点(2)
- 简练软考知识点整理-控制成本过程
- Java知识点整理:第五章:类的声明,构造方法,方法,继承中的构造器,对象实例化过程
- Android动画知识点整理
- 零碎知识点整理
- IO知识点整理(文件File类的使用)
- UNIX环境高级编程--知识点整理(第5.6章)
- VM安装CentOS6.5 minimal 过程(均来源于网络,按照自己的安装过程整理下,方便以后查找)
- SQL 系统存储过程用法整理