写点什么

Coverity Readiness Manager 为代码质量引入可视化度量

  • 2008-09-24
  • 本文字数:1488 字

    阅读完需:约 5 分钟

Coverity 最近发布了其新产品 Software Readiness Manager 的首个版本,该产品针对 Java。Software Readiness Manager 从多处收集并分析基本数据,并从多方面给出分析结果,比如代码复杂度、最佳实践违例、架构完整性、相互依赖以及测试覆盖率。它通过估算风险、对重构进行优先级排序以及估算软件现状来管理开发。

除此之外,Software Readiness Manager 还提供了大量其他的 Java 代码分析工具。InfoQ 最近有幸采访了 Coverity 的首席科学家 Andy Chou,与其讨论了 Coverity Prevent 和 Thread Analyzer。

针对 Java 的 Coverity Prevent 来源于该产品的 C++ 版本。Thread Analyzer 的灵感来源于哪儿呢?

我们看到多核处理器已经成为一种趋势,根据经验我们知道,多线程程序的行为在这种新硬件上开始变得不同。尤其是潜在的竞态条件和死锁会突然间成为最令人头疼的问题。这些问题最难调试了,因为它们很难重现。我们的静态分析产品 Coverity Prevent 也可以发现并发缺陷,但我们知道动态分析可以在测试过程中找到更多的并发缺陷,以此来补充静态分析结果。这样我们就开发了 Thread Analyzer,迄今为止客户的反应都是很积极的。

与一些分析工具相比,比如 Yourkit,你认为 Thread Analyzer 的强项在于哪方面?

Thread Analyzer 主要用来解决多线程代码中最致命的问题。重现并找到一个并发缺陷可能要花费数天甚至数周的时间。甚至在确定了会产生问题的几行关键代码后,依旧难以解耦那些会导致竞态条件或者死锁的交叉存取事件。 Thread Analyzer 使这一切变得清晰而可重现,因此它能在调试或测试时很快找到问题的所在,为你节省大量的时间和精力。分析工具会做很多事情,包括分解应用所花的时间和占据的内存。我想说的是,它们是互补的工具,每种工具的价值取决于所开发应用的类型和当前的实际情况。

最近 blogsphere 上的一个论调就是开源正在谋杀商业开发工具。开源对你们的业务有何影响?

开源为我们的业务带来了实惠——每个代码集都为我们的静态分析系统进行了扩展测试,我们调整算法来最小化失误率、最大化 Bug 发现率,将其用到了极致,所有这一切都轻松搞定。我们也很自豪于通过 Scan( http://scan.coverity.com )向开源社区报告我们的工具所发现的缺陷。到目前为止,开源的开发者通过查询 Scan 上的结果,已经修复了超过 8000 个的缺陷。就开源工具来说,它们确实会对开发工具市场产生一定的影响,但我们发现,对于那些采用先进技术、提供企业级特性和支持、并且一直在其核心价值方面不断进取以保持领先地位的工具来说,依然有很大的空间。那些只是盯着钱而不进行自我改进的工具则会被开源远远甩在后面。

你认为对于创建多线程应用的 Java 开发者来说,最首要的问题是什么呢?

以前我们认为竞态条件是最重要的问题,因为它们会破坏数据,而且很难找到问题的根源。但令我们惊讶的是,很多客户告诉我们死锁才是更重要的问题,因为它会导致应用完全中断。甚至在我们自己内部的开发中,我们的企业架构师也曾说,他认为死锁是在 Java 平台上测试和部署企业应用的一个重要问题。这些看法反映了一些认知的欠缺:竞态条件会导致严重的数据破坏……死锁是很明显的,但竞态条件可能不那么引人注意,这取决于竞态的本质。

下个版本的 Thread Analyzer 会增加什么新特性呢?

我们打算让它与我们的静态分析产品更加紧密地结合,这样它们就能共享彼此的信息以改进性能并找到更多的缺陷。我们还打算在使用多个服务器的分布式程序中检测并发问题。最后,我们还在探求与平台供应商的整合,以让 Thread Analyzer 拥有更多的用户。

查看英文原文: Coverity Readiness Manager Brings Quick Visibility to Code Characteristics

2008-09-24 06:45853
用户头像

发布了 88 篇内容, 共 268.3 次阅读, 收获喜欢 8 次。

关注

评论

发布
暂无评论
发现更多内容

天翼云通过2022可信云安全首批云工作负载保护平台评估

极客天地

加密世界的福音,Galaxy Project上领取专属Zebec OAT

鳄鱼视界

DDD实战(12-终篇):DDD下微服务的“分分合合”及一个倡议

深清秋

DDD 软件架构 8月月更

云原生(二十四) | Kubernetes篇之Kubernetes 配置

Lansonli

云原生 k8s 8月月更

公众版与政企版,这两款云电脑我都要!

天翼云开发者社区

redis持久化持久化的方案与各自存在的问题

想要飞的猪

网站建设流程

源字节1号

网站开发

详解CAN总线:高速CAN总线和低速CAN总线的特性

不脱发的程序猿

汽车电子 ISO 11898 高速CAN总线 低速CAN总线 CAN总线

电商行业:全链路监测广告投放效果,用数据驱动业务增长

HarmonyOS SDK

分析 电商营销

详解AUTOSAR:什么是AUTOSAR?(理论篇—1)

不脱发的程序猿

汽车电子 嵌入式开发 AUTOSAR

头脑风暴:回文子串

HelloWorld杰少

算法 LeetCode 数据结构, 8月月更

GaussDB(DWS)如何实现实时,批量和交付式查询一站式开发

乌龟哥哥

8月月更

算法之“杨辉三角”题解

掘金安东尼

算法 前端 8月月更

短视频软件开发:推荐算法没有想象的那么复杂

开源直播系统源码

直播系统 直播系统源码 短视频直播

英伟达首席科学家:深度学习硬件的过去、现在和未来

OneFlow

机器学习 深度学习 硬件

【算法实践】| 一步步手把手带你实现寻找最小公倍数

迷彩

算法 算法实践 8月月更 最小公倍数

Kubernetes MetalLB 作为 Load Balancer上

CTO技术共享

开源一夏 | 使用layui框架实战之栅格系统和菜单评分组件运用心得

恒山其若陋兮

开源 8月月更

Go-Excelize API源码阅读(十九)——SetHeaderFooter

Regan Yue

Go 开源 源码解析 8月日更 8月月更

Kubernetes MetalLB 作为 Load Balancer下

CTO技术共享

租金、物业费的催收困境,如何解决?

IT资讯搬运工

Kubernetes资源编排系列之五: OAM篇

阿里云大数据AI技术

运维 开放应用模型

程序员过中秋

楠羽

中秋节

IPv6过渡技术的推进策略

穿过生命散发芬芳

ipv6 8月月更

每日一R「13」数据结构(四)闭包

Samson

学习笔记 8月月更 ​Rust

[JS真好玩] 我帮掘金找到了一个小Bug,可利用该Bug增加专栏粉丝数

HullQin

CSS JavaScript html 前端 8月月更

呐,HTTP接口安全的八种对策送给你了

知识浅谈

HTTP API 8月月更

Tomcat 的安装与环境配置

楠羽

开源 #开源

汽车电子控制系统的构成

不脱发的程序猿

汽车电子 嵌入式软件 汽车电子控制系统

架构实战营模块五作业

zhihai.tu

面试突击77:Spring 依赖注入有几种?各有什么优缺点?

王磊

Java 常见面试题

Coverity Readiness Manager为代码质量引入可视化度量_Java_Scott Delap_InfoQ精选文章