启用所有 GCC 警告:编译器配置之旅
一开始,人们可能会认为 -Wall 和 -Wextra 足以激活所有警告GCC 的警告。然而,仔细检查就会发现,这两种选择都不全面。令人沮丧的是,完整的警告列表也是难以捉摸的。
完整性的错觉
GCC 4.4.0 手册提供了看似全面的警告列表。然而,特定于语言的警告分散在 C 、 Objective-C 和其他语言的文档中。此外,该手册仅适用于该特定版本的 GCC。
非必要警告
即使存在完整的列表,打开每个警告也太过分了。例如,-Wdouble-promotion 仅与具有过时浮点功能的 CPU 相关。同样,-Wtraditional 引发了对在现代 C 中完全有效的代码的担忧。
嘈杂且不准确的警告
-Weffc 根据过时的编码指南生成大量警告。这些可能会产生误导,因为它们标记了有效的结构。其他的,比如 -Waggregate-return,会产生在 C 代码中很少有意义的警告。
歧视是必不可少的
用户应该小心,而不是不加区别地打开所有警告考虑每个选项的优点和缺点。例如,-Wall-all,旨在启用所有警告,被 GCC 开发人员标记为“WONTFIX”。
Makefile 自定义
适应编译器和版本变化,在 makefile 中定义特定于编译器的 CFLAGS 很有用。这允许根据目标系统及其特定要求对警告设置进行细粒度控制。
结论
虽然启用所有可能的警告的愿望是可以理解的,这是一个不切实际的目标。用户应该明智地选择适合其特定项目和上下文的最合适的警告。这种方法平衡了彻底的代码分析与可维护性和效率。
以上是如何有效地启用所有 GCC 警告而不过度杀伤?的详细内容。更多信息请关注PHP中文网其他相关文章!