Set*_*jmp 1 c design-patterns include
"C接口和实现"显示了数据结构的一些有趣的使用模式,但我确信还有其他的.
查看戈达德太空飞行中心(NASA)C编码标准(在此URL处).它有一些好的和有趣的指导方针.
我为自己的代码采用的一个特定指南是标题应该是自包含的.也就是说,你应该能够写:
#include "header.h"
Run Code Online (Sandbox Code Playgroud)
并且代码应该正确编译,包括任何其他必要的头文件,无论之前发生了什么.确保这一点的简单方法是在实现源中包含标头 - 作为第一个标头.如果编译,则标题是自包含的.如果它没有编译,请修复它.当然,这也要求您确保标题是幂等的 - 无论它们包含的频率如何都一样.这也是一个标准的习惯用语:
#ifndef HEADER_H_INCLUDED
#define HEADER_H_INCLUDED
...operational body of header.h...
#endif /* HEADER_H_INCLUDED */
Run Code Online (Sandbox Code Playgroud)
当然,必须将#define放在文件的顶部,而不是放在底部.否则,如果这个包含的头也包含header.h,那么你最终会得到一个无限循环 - 不健康.即使你决定采取以下策略:
#ifndef HEADER_H_INCLUDED
#include "header.h"
#endif /* HEADER_H_INCLUDED */
Run Code Online (Sandbox Code Playgroud)
在包含标题的代码中 - 这是一种不推荐的做法 - 将标题包含在标题中也很重要.
上面的GSFC URL不再有效.您可以在问题的答案中找到更多信息.我应该在标题中使用#include,其中还包含对此问题的交叉引用.
可以通过Internet存档访问和下载引用的NASA C编码标准: