SonarQube中文网站 > 使用技巧 > SonarQube扫描c语言代码用C++插件 SonarQube如何使用Jacoco

SonarQube扫描c语言代码用C++插件 SonarQube如何使用Jacoco

发布时间:2025-08-26 11: 22: 00

品牌型号:联想 E550C ThinkPad

系统:Windows 11

软件版本:SonarQube Server 25

SonarQube内包含着众多用于检测代码的工具,如Jacoco代码重复率检测、Checkstyle代码规范检查、CPD重复代码块识别等等,这些工具共同组合成这款支持数十种编程语言的代码质量检测应用,涵盖C语言、Java语言等大众编程语言,而对于新兴语言也以插件的形式予以扩展支持。在下文中,将从SonarQube扫描c语言代码用C++插件,SonarQube如何使用Jacoco两个方面开始,带大家掌握SonarQube的使用方法。

一、SonarQube扫描c语言代码用C++插件

C语言常被用于服务器开发、游戏开发、高性能计算等应用场景中,在SonarQube并没有关于C语言的独立插件,但我们可以使用C++插件对它进行扫描,下面是常用的C++插件:

1、SonarCFamily。SonarQube官方提供了SonarCFamily的C++语言插件,它基于Clang前端实现语法解析,虽然C语言语法和C++之间存在部分差异,但Clang通过编译参数依旧可强制使用该C++插件扫描C语言代码。

对于该插件,并不需要下载安装,我们可以将SonarQube升级到开发版及以上版本,获取对该插件的使用支持。

SonarCFamily
图1:SonarCFamily

2、CppDepend。CppDepend同样也是一款C系列语言插件,内置250多个默认规则,且这些规则与SonarQube的内置规则是互补的,可以检测出C语言代码中的问题、代码覆盖率等SonarQube报告所需指标。

CppDepend
图2:CppDepend

使用时只需将插件放置在“extensions/plugins”文件夹中并重启服务,随后在网页端Quality Profiles中新增一条C语言质量检测设置,设置Parent父项为Sonar way,然后点击Activate More去激活CppDepend的全部规则,最后将该Quality Profiles设置为C语言的默认使用即可。

激活CppDepend规则
图3:激活CppDepend规则

3、PVS-Studio。PVS-Studio可用于检测 Windows、Linux、MacOS系统上关于C、C++、C#和Java源代码中的错误和潜在漏洞,它可轻松与SonarQube集成。

但它并非通过SonarScanner进行扫描,而是先行扫描后生成报告的JSON文件,再利用SonarScanner的“-Dsonar.pvs-studio.reportPath”命令行参数导入其中,用法相对前两个插件而言较为复杂。

PVS-Studio
图4:PVS-Studio

二、SonarQube如何使用Jacoco

Jacoco是一个开源的Java代码覆盖率分析工具,可以生成详细的测试用例代码覆盖率报告,帮助我们评估测试的有效性,它已在SonarQube内置支持,用法也很简单。

1、首先打开网页的Administration管理菜单页面,点击Configuration的JaCoCo设置栏,填写Jacoco覆盖率扫描后生成的XML报告文件地址路径,如“ ../app-it/target/site/jacoco-aggregate/jacoco.xml”,该路径可以是绝对路径,也可以是相对于项目根目录的路径。

设置Jacoco报告路径
图5:设置Jacoco报告路径

2、在Java项目中,安装Jacoco插件,下图是maven项目的安装页面,安装以后需在SonarQube扫描之前,执行“mvn clean test”命令,运行测试以生成覆盖率报告数据。

之后再运行SonarQube扫描程序,此时SonarQube会自动扫描网页端所设置路径的报告,读取报告并汇总计算,最终将结果保存到数据库并呈现在网页端的报告页面中。

Jacoco maven插件
图6:Jacoco maven插件

SonarQube以多种插件实现对C语言和C++语言的统一支持,以Jacoco工具实现对Java覆盖率的精确统计,正是由于包含这些丰富的工具,我们才不需要一个个工具的独立使用测试,而是一步到位生成多样指标的分析报告,这也是SonarQube得天独厚的强大之处。关于SonarQube扫描c语言代码用C++插件,SonarQube如何使用Jacoco就介绍到这,希望本文能提高大家对SonarQube的认识,更多SonarQube其他功能还是需要大家自己去上手尝试。

展开阅读全文

标签:

读者也访问过这里:
SonarQube
从一开始就生成高质量的代码
立即购买
最新文章
SonarQube是代码测试工具吗 SonarQube如何配置SAML
软件代码质量管理从以前到现在经历了翻天覆地的变化,从最初的手工代码审查,到自动化测试工具的出现,再到如今SonarQube等综合检测应用的兴起,软件代码检测越来越正规、专业,带来的是软件市场水平整体的提高。并且SonarQube平台后续还支持通过SAML协议单点登录,大大便利了各大企业内部使用,成为如今众多企业进行代码检测的主要工具。那么SonarQube是代码测试工具吗,SonarQube如何配置SAML,接下来一起来了解一下。
2025-09-22
SonarQube分支分析是什么 SonarQube分支扫描配置与差异报告生成方法
在团队协作开发项目中,多分支并行开发已成为常态,每个不同的团队成员各自负责一部分功能或模块开发,最终由团队Leader统一审阅代码并合并分支。在此过程中,如何把控分支代码质量是一项重难点工作,如果全部代码由Leader人为查看,很容易出现错漏,因此常常需要结合SonarQube等带有分支分析的自动化代码检测工具进行。本文将重点向大家说明SonarQube分支分析是什么,SonarQube分支扫描配置与差异报告生成方法,帮助大家解决这一难点。
2025-09-22
SonarQube代码扫描如何启动 SonarQube代码扫描参数配置步骤
SonarQube提供的代码质量检测功能,在当今“两天一个版本”的快节奏开发环境中,已从“锦上添花”变成了“开发必需”,让我们摆脱传统的“先上线再修复”的恶性循环,它能在代码提交后精准捕捉潜在漏洞和安全问题,将质量问题扼杀在萌芽阶段。检测前我们需先启动扫描程序,下面讲解一下SonarQube代码扫描如何启动,SonarQube代码扫描参数配置步骤。
2025-09-22
SonarQube代码扫描显示cwe吗 SonarQube代码扫描怎么手动上传
互联互通的网络时代,安全性成为软件的主要检测项目之一,越多人使用的应用,它的安全性就越需要被保障,因为任何潜在的漏洞都可能被恶意利用,导致数据泄露、服务中断甚至更严重的系统性风险。因此,我们需要使用SonarQube等检测工具,它们既能帮助开发团队在早期发现代码BUG,还能识别CWE标准的安全漏洞。本文将详细回答大家关于SonarQube代码扫描显示cwe吗,SonarQube代码扫描怎么手动上传的疑问,帮助大家提升代码质量与安全等级。
2025-09-22
SonarQube扫描检测不到新代码 SonarQube扫描规则和检查点
SonarQube的代码扫描主要分为旧代码扫描和新代码扫描两部分,并会在报告中清晰呈现新代码与旧代码的对比分析结果,利用新旧代码的区分,帮助我们将注意力更多放在新代码中,而不被历史遗留问题分散注意力。但是,根据SonarQube设置不同,大家可能会遇到新代码未被正确识别或扫描规则和检查点未正确匹配等情况,因此本文将深入探讨SonarQube扫描检测不到新代码,SonarQube扫描规则和检查点的问题,确保大家得到的扫描结果全面可靠。
2025-09-22
SonarQube扫描原理 SonarQube扫描一定要先build么
什么是静态代码分析?静态代码分析指无需运行代码便可通过分析、检查代码的语法、结构、依赖等来检查代码的正确性,SonarQube的代码检测功能正是建立在静态代码分析原理之上。既然是分析静态代码,那SonarQube扫描前需要先编译代码吗?这个问题看似简单,实际涉及SonarQube扫描底层原理。想要获取正确代码检测结果,建议读者一起跟随本文,了解SonarQube扫描原理,SonarQube扫描一定要先build么的问题答案。
2025-09-22

读者也喜欢这些内容:

咨询热线 18015636924