软件构造 6-1 Robustness and Correctness

2023-10-15 02:40

本文主要是介绍软件构造 6-1 Robustness and Correctness,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

6.1 健壮性与正确性

一. 健壮性

  1. 健壮性:系统在不正常输入不正常外部环境下仍能够表现正常的程度。

  2. 面向健壮性编程有以下特征:

  • 处理未期望的行为和错误终止
  • 即使终止执行,也要准确 / 无歧义的向用户展示全面的错误信息
  • 错误信息有助于进行 debug

  3. Postel’s Law

  • 总是假定用户恶意、假定自己的代码可能失败
  • 把用户想象成白痴,可能输入任何东西。此时返回给用户的错误提示信息要详细、准确、无歧义

  对自己的代码要保守,对用户的行为要开放。

  4. 健壮性实现原则:

  • 封闭实现细节,限定用户的恶意行为
  • 考虑极端情况,没有“不可能”

二. 正确性

  1. 正确性:程序按照 spec 加以执行的能力,这是最重要的质量指标。

  2. 正确性与健壮性:

  • 正确性:永不给用户错误的结果
  • 健壮性:尽可能保持软件运行而不是总是退出

  正确性倾向于直接报错 (error),健壮性则倾向于容错 (fault tolerance) 。


  例如:

在这里插入图片描述

  或者例如:
在这里插入图片描述


  使用角度

  • 健壮性:让用户变得更容易:出错也可以容忍,程序内部已有容错机制
  • 正确性:让开发者变得更容易:用户输入错误(不满足 precondition 的调用),直接结束。

  接口角度

  • 面向真实用户的对外的接口、面向客户端(或可能被他人调用)的接口。其倾向于健壮性
  • 对内的接口(自己使用但别人不可能使用)。倾向于正确性

三. 相关定义

  1. 可靠性 = 健壮性 + 正确性

  2. 相关术语:

  • 错误 (error ≈ mistake) :程序员犯的错误
  • 缺陷 (defect) : bug 的根源
  • fault (defect ≈ fault, bug)
  • 失效 (failure) :运行时的外在表现(缺陷爆发、程序宕机)

  因果关系:error → defect/fault/bug → failure
  程序员犯错导致软件存在缺陷,导致软件运行时失效

四. 过滤缺陷、提升健壮性与正确性

  编程时:

  • :使用断言、防御性编程、代码评审、形式化验证等方法来编写具有健壮性和正确性目标的代码

  编程后:

  • 观察故障症状 (内存转储、堆栈跟踪、执行日志、测试)
  • 识别潜在的错误 (错误定位,调试)
  • 修复错误 (代码修订)

  MTBF 平均失效间隔时间 (外部观察角度,直接):两次邻近的失效的平均时间间隔。
  由于部分系统可以自我修复并且修复时不能访问系统,因此通常 MTBF 是两个时间的加和:修复时间 + 紧邻的失效时间。在这里插入图片描述


  残余缺陷率(内部观察角度,间接):每千行代码中遗留的 bug 的数量。

  • 1-10 defects / kloc
  • 0.1-1 defects / kloc
  • 0.01-0.1 defects / kloc

  Halstead Volume:基于源代码中(不同的)操作符和操作数的数量的复合度量。


在这里插入图片描述

这篇关于软件构造 6-1 Robustness and Correctness的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/214837

相关文章

Ubuntu 怎么启用 Universe 和 Multiverse 软件源?

《Ubuntu怎么启用Universe和Multiverse软件源?》在Ubuntu中,软件源是用于获取和安装软件的服务器,通过设置和管理软件源,您可以确保系统能够从可靠的来源获取最新的软件... Ubuntu 是一款广受认可且声誉良好的开源操作系统,允许用户通过其庞大的软件包来定制和增强计算体验。这些软件

软件设计师备考——计算机系统

学习内容源自「软件设计师」 上午题 #1 计算机系统_哔哩哔哩_bilibili 目录 1.1.1 计算机系统硬件基本组成 1.1.2 中央处理单元 1.CPU 的功能 1)运算器 2)控制器 RISC && CISC 流水线控制 存储器  Cache 中断 输入输出IO控制方式 程序查询方式 中断驱动方式 直接存储器方式(DMA)  ​编辑 总线 ​编辑

【STM32】SPI通信-软件与硬件读写SPI

SPI通信-软件与硬件读写SPI 软件SPI一、SPI通信协议1、SPI通信2、硬件电路3、移位示意图4、SPI时序基本单元(1)开始通信和结束通信(2)模式0---用的最多(3)模式1(4)模式2(5)模式3 5、SPI时序(1)写使能(2)指定地址写(3)指定地址读 二、W25Q64模块介绍1、W25Q64简介2、硬件电路3、W25Q64框图4、Flash操作注意事项软件SPI读写W2

免费也能高质量!2024年免费录屏软件深度对比评测

我公司因为客户覆盖面广的原因经常会开远程会议,有时候说的内容比较广需要引用多份的数据,我记录起来有一定难度,所以一般都用录屏工具来记录会议内容。这次我们来一起探索有什么免费录屏工具可以提高我们的工作效率吧。 1.福晰录屏大师 链接直达:https://www.foxitsoftware.cn/REC/  录屏软件录屏功能就是本职,这款录屏工具在录屏模式上提供了多种选项,可以选择屏幕录制、窗口

leetcode105 从前序与中序遍历序列构造二叉树

根据一棵树的前序遍历与中序遍历构造二叉树。 注意: 你可以假设树中没有重复的元素。 例如,给出 前序遍历 preorder = [3,9,20,15,7]中序遍历 inorder = [9,3,15,20,7] 返回如下的二叉树: 3/ \9 20/ \15 7   class Solution {public TreeNode buildTree(int[] pr

HomeBank:开源免费的个人财务管理软件

在个人财务管理领域,找到一个既免费又开源的解决方案并非易事。HomeBank 正是这样一个项目,它不仅提供了强大的功能,还拥有一个活跃的社区,不断推动其发展和完善。 开源免费:HomeBank 是一个完全开源的项目,用户可以自由地使用、修改和分发。用户友好的界面:提供直观的图形用户界面,使得非技术用户也能轻松上手。数据导入支持:支持从 Quicken、Microsoft Money

PDF 软件如何帮助您编辑、转换和保护文件。

如何找到最好的 PDF 编辑器。 无论您是在为您的企业寻找更高效的 PDF 解决方案,还是尝试组织和编辑主文档,PDF 编辑器都可以在一个地方提供您需要的所有工具。市面上有很多 PDF 编辑器 — 在决定哪个最适合您时,请考虑这些因素。 1. 确定您的 PDF 文档软件需求。 不同的 PDF 文档软件程序可以具有不同的功能,因此在决定哪个是最适合您的 PDF 软件之前,请花点时间评估您的

梳理2024年,螺丝钉们爱用的3款剪辑软件

这年头,视频到处都是,就跟天上的星星一样数不清。不管你是公司里的新面孔,还是职场上的老狐狸,学会怎么剪视频,就好比找到了赢的秘诀。不管是给上司汇报工作,展示你的产品,还是自己搞点小视频记录生活,只要是剪辑得漂亮,肯定能一下子吸引大家的目光,让人记得你。咱们今天就来侃侃现在超火的三款视频剪辑工具,尤其是PR剪辑,你肯定听说过,这货在剪辑界可是大名鼎鼎,用它剪视频,既专业又麻利。 NO1. 福昕轻松

秒变高手:玩转CentOS 7软件更换的方法大全

在 CentOS 7 中更换软件源可以通过以下步骤完成。更换源可以加快软件包的下载速度,特别是当默认源速度较慢时。以下是详细步骤: 前言 为了帮助您解决在使用CentOS 7安装不了软件速度慢的问题,我们推出了这份由浪浪云赞助的教程——“CentOS7如何更换软件源加快下载速度”。 浪浪云,以他们卓越的弹性计算、云存储和网络服务受到广泛好评,他们的支持和帮助使得我们可以将最前沿的技术知识分

excel翻译软件有哪些?如何高效提翻译?

你是否曾在面对满屏的英文Excel表格时感到头疼?项目报告、数据分析、财务报表... 当这些重要的信息被语言壁垒阻挡时,效率和理解度都会大打折扣。别担心,只需3分钟,我将带你轻松解锁excel翻译成中文的秘籍。 无论是职场新人还是老手,这一技巧都将是你的得力助手,让你在信息的海洋中畅游无阻。 方法一:使用同声传译王软件 同声传译王是一款专业的翻译软件,它支持多种语言翻译,可以excel