0

0

c++怎么使用clang-tidy静态分析_c++ 代码规范检查与错误预防【教程】

尼克

尼克

发布时间:2025-12-31 06:41:17

|

914人浏览过

|

来源于php中文网

原创

clang-tidy 是基于 Clang 的 C++ 静态分析工具,用于检测代码规范、潜在缺陷(如 nullptr 解引用、未使用变量)和现代 C++ 用法问题,依赖 compile_commands.json 获取编译参数,并通过可配置的检查项(如 cppcoreguidelines-、modernize-)实现精准诊断。

c++怎么使用clang-tidy静态分析_c++ 代码规范检查与错误预防【教程】

clang-tidy 是什么,它能帮你发现哪些问题

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 真正跑起来并接入项目

直接运行 clang-tidy 命令却报错“no compile commands”,这是最常见卡点——它需要知道每个源文件的完整编译参数(尤其是头文件路径、宏定义、C++ 标准版本),不能靠猜。

  • 对 CMake 项目:在配置时加 -DCMAKE_EXPORT_COMPILE_COMMANDS=ON,生成 compile_commands.json
  • 对非 CMake 项目:可用 bear --makecompiledb make 拦截编译过程生成该文件
  • 运行时指定路径:clang-tidy -p build/ main.cpp-p 后跟含 compile_commands.json 的目录)

不带 -p 直接传文件名,clang-tidy 会用默认参数尝试解析,几乎必然失败。

立即学习C++免费学习笔记(深入)”;

ModelGate
ModelGate

一站式AI模型管理与调用工具

下载

怎么选检查项,避免被警告刷屏

开箱即用的 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 控制范围
  • CI 中若用 clang-tidy -fix 自动修复,务必确认目标文件权限可写,且 compile_commands.json 是最新生成的——旧缓存会导致修复应用到错误上下文

它不会替你决定是否该用 std::shared_ptr,但能指出某处裸指针正在跨函数传递且无所有权说明——这个信号是否处理,取决于你对模块边界的判断,而不是工具本身。

相关专题

更多
json数据格式
json数据格式

JSON是一种轻量级的数据交换格式。本专题为大家带来json数据格式相关文章,帮助大家解决问题。

402

2023.08.07

json是什么
json是什么

JSON是一种轻量级的数据交换格式,具有简洁、易读、跨平台和语言的特点,JSON数据是通过键值对的方式进行组织,其中键是字符串,值可以是字符串、数值、布尔值、数组、对象或者null,在Web开发、数据交换和配置文件等方面得到广泛应用。本专题为大家提供json相关的文章、下载、课程内容,供大家免费下载体验。

528

2023.08.23

jquery怎么操作json
jquery怎么操作json

操作的方法有:1、“$.parseJSON(jsonString)”2、“$.getJSON(url, data, success)”;3、“$.each(obj, callback)”;4、“$.ajax()”。更多jquery怎么操作json的详细内容,可以访问本专题下面的文章。

306

2023.10.13

go语言处理json数据方法
go语言处理json数据方法

本专题整合了go语言中处理json数据方法,阅读专题下面的文章了解更多详细内容。

74

2025.09.10

C++类型转换方式
C++类型转换方式

本专题整合了C++类型转换相关内容,想了解更多相关内容,请阅读专题下面的文章。

289

2025.07.15

excel制作动态图表教程
excel制作动态图表教程

本专题整合了excel制作动态图表相关教程,阅读专题下面的文章了解更多详细教程。

24

2025.12.29

freeok看剧入口合集
freeok看剧入口合集

本专题整合了freeok看剧入口网址,阅读下面的文章了解更多网址。

74

2025.12.29

俄罗斯搜索引擎Yandex最新官方入口网址
俄罗斯搜索引擎Yandex最新官方入口网址

Yandex官方入口网址是https://yandex.com;用户可通过网页端直连或移动端浏览器直接访问,无需登录即可使用搜索、图片、新闻、地图等全部基础功能,并支持多语种检索与静态资源精准筛选。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

207

2025.12.29

python中def的用法大全
python中def的用法大全

def关键字用于在Python中定义函数。其基本语法包括函数名、参数列表、文档字符串和返回值。使用def可以定义无参数、单参数、多参数、默认参数和可变参数的函数。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

16

2025.12.29

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
WEB前端教程【HTML5+CSS3+JS】
WEB前端教程【HTML5+CSS3+JS】

共101课时 | 8.1万人学习

JS进阶与BootStrap学习
JS进阶与BootStrap学习

共39课时 | 3.1万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号