clang-tidy 是基于 Clang 的 C++ 静态分析工具,用于检测代码规范、潜在缺陷(如 nullptr 解引用、未使用变量)和现代 C++ 用法问题,依赖 compile_commands.json 获取编译参数,并通过可配置的检查项(如 cppcoreguidelines-、modernize-)实现精准诊断。
clang-tidy 不是编译器,而是一个基于 Clang 的 C++ 静态分析工具,专为检查代码规范、潜在缺陷和现代 C++ 用法设计。它不替代 g++ 或 clang++ 编译,但能提前暴露 nullptr 解引用、未使用的变量、遗漏的 override、裸指
针误用、不安全的类型转换等真实风险。
它通过“检查项(checks)”工作,比如 cppcoreguidelines-pro-bounds-array-to-pointer-decay 检查数组退化为指针的问题,modernize-use-auto 提示可改用 auto 的地方。这些检查大多对应《C++ Core Guidelines》或 Google C++ Style Guide 等规范。
直接运行 clang-tidy 命令却报错“no compile commands”,这是最常见卡点——它需要知道每个源文件的完整编译参数(尤其是头文件路径、宏定义、C++ 标准版本),不能靠猜。
-DCMAKE_EXPORT_COMPILE_COMMANDS=ON,生成 compile_commands.json
bear --make 或 compiledb make 拦截编译过程生成该文件clang-tidy -p build/ main.cpp(-p 后跟含 compile_commands.json 的目录)不带 -p 直接传文件名,clang-tidy 会用默认参数尝试解析,几乎必然失败。
开箱即用的 clang-tidy 默认只启用少量基础检查,实际需主动启用有意义的规则集。盲目启用全部(如 -checks='*')会导致大量低价值告警(比如所有 using namespace std; 都报),反而掩盖真正危险的问题。
推荐组合策略:
-checks='-*,cppcoreguidelines-*,modernize-*,bugprone-*,performance-*,readability-*,再手动排除个别干扰项(如 -cppcoreguidelines-pro-type-vararg)bugprone- 和 performance- 类别,它们指向真 bug 或性能隐患;readability- 可后期逐步接入.clang-tidy,内容如Checks: '-*,cppcoreguidelines-*,modernize-use-auto,bugprone-unused-raii' WarningsAsErrors: false HeaderFilterRegex: '^(include|src)/',后续所有
clang-tidy 调用自动读取很多人把 clang-tidy 当成“偶尔跑一下”的工具,结果问题反复出现。真正起效要嵌入日常环节,但有三个细节常被跳过:
clang-tidy 对 C++ 标准版本敏感:如果项目用 c++17,必须确保 compile_commands.json 中对应条目含 -std=c++17,否则 std::optional 等特性会被误判为未声明clang-tidy file.cpp 不会重新检查其包含的头文件;需配合 --header-filter=.* 并显式列出头文件,或使用 clang-tidy -fix 时加 --header-filter 控制范围clang-tidy -fix 自动修复,务必确认目标文件权限可写,且 compile_commands.json 是最新生成的——旧缓存会导致修复应用到错误上下文它不会替你决定是否该用 std::shared_ptr,但能指出某处裸指针正在跨函数传递且无所有权说明——这个信号是否处理,取决于你对模块边界的判断,而不是工具本身。