11.5 一个头文件可以包含另一头文件吗?
这是个风格问题, 因此有不少的争论。 很多人认为 ``嵌套包含文件" 应该避免:
盛名远播的 ``印第安山风格指南"(Indian Hill Style Guide, 参见问题 17.7)
对此嗤之以鼻;
它让相关定义更难找到; 如果一个文件被包含了两次, 它会导致重复定义错误;
同时他会令 makefile 的人工维护十分困难。 另一方面, 它使模块化使用头文件
成为一种可能 (一个头文件可以包含它所需要的一切, 而不是让每个源文件都包含
需要的头文件); 类似 grep 的工具 (或 tags 文件) 使搜索定义十分容易, 无论
它在哪里; 一种流行的头文件定义技巧是:
#ifndef HFILENAME_USED
#define HFILENAME_USED
... 头文件内容 ...
#endif
每一个头文件都使用了一个独一无二的宏名。这令头文件可自我识别,以便
可以安全的多次包含; 而自动 Makefile 维护工具 (无论如何, 在大型项目中都
是必不可少的) 可以很容易的处理嵌套包含文件的依赖问题。 参见问题 17.8。
参考资料: [Rationale, Sec. 4.1.2]。
翻译朱群英、孙云, LaTeX2HTML 编译 朱群英 (2005-06-23)