阅读log4cplus源代码过程中的小知识点整理
来源:互联网 发布:金华亿途网络 编辑:程序博客网 时间:2024/05/16 10:04
开始阅读log4cplus源代码,这个库规模不大,但作者的C++功底不错(至少我个人认为),而且更新的相当频繁,作为学习C++的实际分析对象不错。log4cplus源代码中用到了Singleton、Factory Method、Bridge、Observer等等Pattern,还有Pimpl机制、引用计数机制等等,非常值得总结学习。不过,这篇文章,主要用来记录,阅读代码过程中的C++小知识点,偶有所得,都会持续更新,也希望得到有缘进来的朋友的留言指正,先谢啦。
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源代码过程中的小知识点整理
- 阅读log4cplus源代码过程中的小知识点整理(持续更新)
- mongoose源码阅读过程中的小知识点(2)
- Javascript 中的小知识点整理
- Iphone界面设计中的小知识点整理
- ios开发过程中的小知识点
- Android开发过程中的几个小知识点
- 开发过程中的小错误整理
- 整理小知识点
- Android小知识点整理
- React小知识点整理
- 数据结构小知识点整理
- Struts2 小知识点整理
- Python整理小知识点
- java 小知识点整理
- 小知识点整理
- iOS巅峰之项目中的一些小知识点整理
- iOS巅峰之开发过程中的小知识点大全
- D3D学习笔记(初始化Direct3D-2)
- 在内网建一个FTP服务器,并且可以通过外网访问
- 提供一个在测试环境中,监控应用服务器的外部接口调用的方法(高峰)
- Linux系统文件I/O编程(一)---open()等基本函数
- const变量真的不能修改吗?
- 阅读log4cplus源代码过程中的小知识点整理
- netty入门学习(1)-从NIO说起
- Adapter中函数的调用顺序
- C++ 库
- 神经网络编程入门
- 二分查找需要注意的问题,以及在数据库内核中的实现
- navicat for mysql导出表结构
- HTTP响应头信息
- 黑马程序员——面向对象三大特征(封装、继承、多态)