软件系统的质量属性
外部质量因素
- 保持正确性(Correctness)
1.确保接收的条件是正确的
分层:假定一个软件系统是分层开发的,每层都要确保自己是正确的,同时假定其调用的低层也是正确的。
2.测试与调试
a)防御式编程
b)证明自己的代码能满足预期要求。
- 保持健壮性(Robustness)
1.健壮性是软件系统对异常情况作出适当反应的能力。稳健性是为了确保如果出现某种情况,系统不会导致灾难性的(灾难性)事件; 它应该产生适当的错误信息,干净地终止执行,或进入某种解决方案
2.健壮性同异常情况相关,异常或非异常取决于程序的规 格说明。异 常情况是程序的规格说明中没有涉及的部分
3.判断是否是异常的标准,不取决于客观的正确标准,而取决于程序的规格说明
- 可扩展性(Extendibility)
1.可扩展性是指软件易于调整以适应变化的能力。可扩展性同规模密切相关,规模越大越难以扩展。因为软件是易变的,需 要可扩展性。
2.传统的方法没有充分考虑变化,只考虑当前的需求,大部分时间花费在设计和构建解决方案上
简单的体系结构总是比复杂的体系更容易适 应变化。模块自治性越强,变化时对其余模块影响 越小。
- 可复用性(Reusability)
软件经常遇到相似的模式,利用共性,避 免重复实现。
- 兼容性(Compatibility)
1.用于软件与其他元素简便地结合,即软件与其他软件或者文件的交互
2.举例:许多操作系统支持的各种不兼容的文件格式;而只有在文件格式兼容的情况下,程序才能直接使用另一个程序的结果作为输入。
3.解决方案:
a)标准化是解决兼容性的关键。
b)通过协议来实现更通用的兼容性
- 效率(Efficiency)
效率是指软件系统尽可能少地对硬件资源提出要求的能力,例如处理器时间,内部和外部存储器占用的空间,通信设备中使用的带宽。
1.注意,提高效率的同时要保证一定正确
2.提高效率要与健壮性等其他指标相平衡
3.可以通过算法优化,I/O策略,内存设置来提高效率
- 可移植性(Portability)
可移植性是指便于将软件产品 转移到各种硬件和软件环境。
- 便于使用(Ease of use)
用户可以轻松掌握软件的使用,也包括安 装、运行和监控的容易度
- 功能性(Functionality)
有时候,软件开发者增加越来越多的功能,企图跟上竞争,结果导致程序极为复杂、不灵活、占用过多的磁盘空间,过多的新功能容易带来一 致性的缺失,影响易用性。在质量提升技术的帮助下,可以在整个项目中保持质量水平不变,而不仅仅是功能性。
- 其他
Verifiability(可验证性) :是否易于验证
Integrity(完整性) : 软件系统保护其各种组件(程序和数据)免受未经授权的 访问和修改的能力。
Economy(经济):同及时性相伴,是系统能 够按照其分配的预算或低于预算完成的能力。
内部质量因素
内部质量因素通常用作外部质量因素的部分度量。
- 圈复杂度, 用来衡量一个模块判定结构的复杂程度
- 耦合度,内聚度等。耦合指多个模块之间互相渗入交互。设计中追求高内聚和低耦合。
- 易读性
- 复杂性
- 规模
各个属性间的权衡
- 开发人员通常都是隐式地进行平衡,不会刻意的在多个方案中均衡,效率往 往成为主导因素。
- 真正的软件工程方法中,质量目 标应明确指出
- 正确性放在首要地位
理解
这一章作为软件构造这门课绪论性质的章节,把公司进行软件编程要求的性质讲的很明白。在大型软件设计的时候,要遵循相应的原则,把握住各个性能之间的平衡。