快手、孩子王、华为等专家分享大模型在电商运营、母婴消费、翻译等行业场景的实际应用 了解详情
写点什么

使用复杂度度量去改进软件质量

  • 2014-10-27
  • 本文字数:967 字

    阅读完需:约 3 分钟

复杂度度量可以用来评估开发和测试活动,决定应该对哪里进行重构以提升质量和预防问题。在 QA&Test 2014 conference 大会上,来自于英特尔的 Shashi Katiyar 就有效利用针对软件质量改进的复杂度度量提出了自己的见解。

复杂度是一种不同的软件元素间交互的度量。按照 Shashi 的说法,软件复杂度直接反映了软件的质量和成本:如果代码复杂度比较高,那么这段代码的质量就会比较低,而且它的维护成本也会比较高。

Shashi 提出,如果软件产品中有复杂的代码,那么组织会面临以下的问题:

  • 较高的缺陷风险
  • 难以增加新的功能
  • 难以理解或维护这段代码
  • 难以验证

你可以使用 McCabe 圈复杂度来度量复杂度。这种度量规定了代码中线性独立的路径条数,它反映了测试难度和软件的可靠性。它可以用来评估开发和维护工作量。

基于复杂度数据,你掌握要覆盖所有路径最少需要多少测试用例。复杂度数据可以帮助你去:

  • 集中力量搞好复杂的模块
  • 找到最有效的测试技术
  • 了解停止测试的时机
  • 增加软件的可测试性

Shashi 解释说,你在软件系统的管理中做到更具可预测性:

在任何软件产品开始工作之前,如果有人知道它是一个复杂的模块,那么就有可能在评估期为它赋予一些额外的时间。了解了复杂度能够预先帮助项目团队去进行评估,这种做法要胜过在开发和测试期去关注它,从而确保不会让产品的质量做出妥协。

英特尔收集了复杂度度量和模块变更数量的数据。这些复杂度数据结合了客户记录的缺陷。如果一个模块是复杂的,并且由于缺陷进行了大量的变更,那么就决定去重构它。在重构之前他们确保有覆盖这些代码的测试用例。这种工作方式增加了重构的投资收益率。

Shashi 探讨了他所看到的软件开发复杂度与质量相关的挑战:

在竞争激烈瞬息万变的环境中,公司通过为它的用户提供更多的特性来努力使它的服务有所不同。这就导致了大量的代码行和复杂度,这是个大挑战。如果未采用适当的预防措施去管理产品的复杂度,那么很快这些产品就将成为难以维护的产品。随着时间的推移,很多公司都不在使用老代码和老技术了,他们知道自己的系统太复杂了,把它们进行新技术的移植是一项极其复杂的任务。

“在高复杂度的环境中,创新和开发高质量软件是极其重要的”Shashi 说。“组织可以设定去减少所有高复杂度程序的复杂度,更加频繁地变更以改进他们软件的质量”。

查看英文原文: Using Complexity Measurements to Improve Software Quality

2014-10-27 08:222583

评论

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

一文读懂Js中的this指向

hellocoder2029

JavaScript

从手动测试到自动化测试(上)

FunTester

详解CAN总线:CAN总线报文格式—帧间隔

不脱发的程序猿

汽车电子 CAN总线报文格式 详解CAN总线 CAN帧间隔

2022-10-10:以下go语言代码输出什么?A:[1 2 3 0 1 2];B:死循环;C:[1 2 3 1 2 3];D:[1 2 3]。 package main import “fmt“

福大大架构师每日一题

golang 福大大 选择题

令人头疼的Javascript隐式&强制转换

hellocoder2029

JavaScript

IDEA的Docker插件实战(Docker-compose篇)

程序员欣宸

Docker Docker-compose 10月月更

Spring Boot「02」日志配置

Samson

Java spring 学习笔记 spring-boot 10月月更

网络安全【漏洞安全】反序列化漏洞深入分析

网络安全学海

黑客 网络安全 信息安全 渗透测试 漏洞挖掘

数据结构学习,栈篇(链式栈)

IC00

读书笔记 数据结构 算法 10月月更

数据库自动化运维实践

穿过生命散发芬芳

数据库运维 10月月更

李宏毅《机器学习》P1-P2 学习笔记

Clarke

Beautiful Soup库的介绍

芯动大师

Python BeautifulSoup 10月月更

强大的爬虫框架 Scrapy

芯动大师

Scrapy scrapy框架 10月月更

数据治理,七种常犯的错误

雨果

数据治理

详解CAN总线:CAN总线报文格式—过载帧

不脱发的程序猿

汽车电子 CAN总线报文格式 详解CAN总线 CAN过载帧

cstdio的源码学习分析08-设置文件流buffer函数setbuf

桑榆

源码刨析 10月月更 C++

Spring之DI依赖注入

楠羽

笔记 spring】 10月月更

Spring JPA 如何进行无参数查询布尔类型

HoneyMoose

大数据ELK(二十一):Logstash简介和安装

Lansonli

Logstash 10月月更

js作用域、作用域链和它的一些优化

hellocoder2029

JavaScript

后端Java随机比大小游戏实战讲解

魏铁锤

10月月更

【愚公系列】2022年10月 Go教学课程 024-函数

愚公搬代码

10月月更

一文搞懂CAN总线协议帧格式

不脱发的程序猿

汽车电子 CAN总线 CAN总线协议帧格式

Web前端 | HTML5学习

亮点

html web前端 10月月更

践行ESG理念,缘何成为消费金融行业共识?

易观分析

金融 ESG

requests的介绍

芯动大师

Python requests 10月月更

数据中台与业务中台的区别与联系

阿泽🧸

业务中台 10月月更

Java 泛型

Yeats_Liao

后端 Java后端 Java core 10月月更

字符串拆分----split()关键字

魏铁锤

10月月更

详解CAN总线:CAN总线报文格式—遥控帧

不脱发的程序猿

汽车电子 CAN总线报文格式 详解CAN总线 CAN遥控帧

详解CAN总线:CAN总线报文格式—错误帧

不脱发的程序猿

汽车电子 CAN总线报文格式 详解CAN总线 CAN错误帧

使用复杂度度量去改进软件质量_软件工程_Ben Linders_InfoQ精选文章