发布时间:2025-08-30 08: 00: 00
品牌型号:联想 E550C ThinkPad
系统:Windows 11
软件版本:SonarQube Server 25
随着C++项目代码行数的日渐增加,传统的人工审阅代码模式已无法及时发现海量代码中可能存在的问题漏洞。SonarQube作为代码分析、质量检测的工具,通过其内部数百条专为C++语言定制的扫描规则,构成了覆盖代码安全性、可靠性、可维护性等多个维度的智能防护体系。对于刚接触SonarQube的开发团队而言,建议阅读并理解下文关于SonarQube C++代码检查,SonarQube代码扫描质量规则的内容,它们能帮助团队更好地确保代码质量。
一、SonarQube C++代码检查
SonarQube中支持多种C++语法标准,如C++11、C++14、C++17等,并能根据内部的C++规则检查代码的潜在问题,使用前需确保SonarQube至少升级到开发者版本,具体代码检查步骤如下:
1、下载Build Wrapper。由于C++属于预编译语言,因此在分析前需要先进行build构建步骤,一般建议使用Build Wrapper进行构建,原因一在于它会强制在分析之前运行构建,并且生成的源文件在分析期间可用,原因二在于它被SonarQube所推荐和支持。
SonarQube已经帮我们提供了下载Build Wrapper的URL,Windows只需要在浏览器中浏览“

2、运行构建。将Build Wrapper执行目录添加到环境变量中,然后在C++项目根目录下打开终端,并输入“build-wrapper-win-x86-64.exe --out-dir build_wrapper_output_directory MSBuild.exe /t:Rebuild /nodeReuse:False”命令执行,执行完成后会生成三个文件:build-wrapper-dump.json、compile_commands.json和build-wrapper.log。

3、添加配置执行。在项目根目录下创建“sonar-project.properties”的配置文件,在其中添加“sonar.cfamily.compile-commands”的设置并指定为上述编译后生成的“compile_commands.json”文件,最后执行SonarQube网页端提供的项目扫描命令即可完成C++代码扫描检查。

二、SonarQube代码扫描质量规则
SonarQube的代码扫描质量规则是其分析识别代码问题能力的核心功能,可以说质量规则的完整决定了扫描质量的高低,下面是关于代码扫描质量规则的一些重要内容:
1、质量配置。在SonarQube的Quality Profiles页面中,包含了各种语言的质量配置文件,在Filter by下拉框中可以筛选语言对应的质量配置,点击某个配置进入配置详情页,可以看到不同配置有不同的绑定规则,如C#质量配置中当前包含321条激活扫描规则。我们可以为自己的编程语言配置自定义的Quality Profiles以满足特定需求。

2、扫描规则类别可见规则左下角的标签,按识别问题的类型主要分为三大类:
①Security:安全问题,表示代码可能存在的安全隐患,如SQL注入、敏感数据泄露。
②Reliability: BUG问题,表示代码中可能导致运行时出现错误、崩溃的问题,这些问题不会直接被编译器捕获,但会在运行时报错。
③Maintainability:可维护性问题,主要用于提高代码可读性和可维护性,常见报错情形为代码行过长、常量未定义、函数参数过多等。

以上就是SonarQube C++代码检查,SonarQube代码扫描质量规则的讲解内容。在C++等软件开发过程中,代码质量问题不应该是一个项目收尾时再考虑的补漏工程,而应贯穿于整个开发周期,在每次提交或每个版本都使用SonarQube进行一次代码检测。SonarQube丰富的扫描质量规则和各种强大的工具箱,都是它值得信赖的有效证明。
展开阅读全文
︾
读者也喜欢这些内容:
SonarQube平台中可以查看git的地址吗 SonarQube可以判断是否修改代码吗
如何高效地实现代码质量管控与版本控制的深度结合,一直是开发者们重要关注的内容。是否有这样一款工具,它既能无缝对接GitHub、GitLab等主流代码托管平台,自动获取仓库项目代码;又能识别新旧代码变更,精准聚焦于修改部分进行针对性的质量检测与分析?SonarQube正是这样一款软件,在这里,相信有不少人要问:SonarQube平台中可以查看git的地址吗,SonarQube可以判断是否修改代码吗?答案是可以,下面告诉大家如何操作。...
阅读全文 >
SonarQube连接不上数据库 SonarQube配置完数据库启动闪退
SonarQube为什么要连接数据库?一方面是庞大代码分析数据的持久化存储需求,能确保数据不轻易丢失,也能确保和历史结果进行对比;另一方面是借助数据库索引实现强大的高效检索能力。我们在使用SonarQube连接数据库时,可能出现连接不上或启动闪退等问题,但大家不用害怕,读完下文对SonarQube连接不上数据库,SonarQube配置完数据库启动闪退的解决方案介绍,大家也能独立完成数据库的连接使用。...
阅读全文 >
SonarQube代码扫描安装和使用 SonarQube代码扫描规则及解决方案
很多项目代码在进行测试时看似正常,但其实内部已经隐藏了难以察觉的漏洞或安全问题,这些潜在问题如同定时炸弹,往往在系统正式上线后,经过大规模用户使用和复杂场景考验时才突然爆发,此时发现却已为时已晚。为了避免此类情况发生,建议项目在上线前要经过SonarQube的代码扫描检测方可安心。而关于SonarQube代码扫描安装和使用,SonarQube代码扫描规则及解决方案的讲解,本文将详细说明,大家感兴趣可以往下阅读。...
阅读全文 >