软件构造博客(7)-Robustness and Correctness

2023-10-15 02:40

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

前言

进入软件构造最关键的质量特性——健壮性和正确性。
使用错误处理和exception提高robustness
使用断言、防御式编程提高correctness

含义

健壮性:系统在不正常输入或不正常外部环境下仍能够表现正常的程度
面向健壮性的编程:
1.处理未期望的行为和错误终止
2.即使终止执行,也要准确/无歧义的向用户展示全面的错误信息
3.错误信息有助于进行debug
正确性:程序按照spec加以执行的能力,是最重要的质量指标

区别

正确性:永不给用户错误的结果
健壮性:尽可能保持软件运行而不是总是退出
正确性倾向于直接报错(error),健壮性则倾向于容错(fault-tolerance)
在这里插入图片描述
在这里插入图片描述

Reliability = Robustness + Correctness

Error and Exception in Java

所有 Exception 对象的基类是 java.lang.Throwable,以及它的两个子类 java.lang.Exception 和 java.lang.Error
在这里插入图片描述

注意:checked Exception:MUST be caught or declared to be throw

不要抛出Error对象:Error 类描述内部系统错误和资源,Java 运行时系统内的耗尽情况(例如,
VirtualMachineError, LinkageError) 很少发生– 你不应该抛出这种类型的对象

内部错误:程序员通常无能为力,一旦发生,想办法让程序优雅的结束

用户输入错误
设备错误
物理限制
在这里插入图片描述

异常:你自己程序导致的问题,可以捕获、可以处理

Exception Handling

既然Error我们无能为力,那就转向关注我们能处理的Exception
异常:
1.程序执行中的非正常事件,导致程序无法再按预想的流程执行
2.Exceptions将错误信息传递给上层调用者,并报告“案发现场”的信息
3.return之外的第二种退出途径
4.若找不到异常处理程序,整个系统完全退出

异常处理的优势

1.你不能忘记处理常见的故障模式
– 比较:使用标志或特殊返回值
2. 提供错误的高级摘要和堆栈跟踪
– 比较:C 中的核心转储
3. 改进代码结构
– 将正常代码路径与异常代码路径分开

  • 轻松从失败中恢复的任务
  1. 轻松编写健壮、可维护的代码
    反例
    在这里插入图片描述
    在这里插入图片描述
异常分类-从是否为RuntimeException的角度

在进行 Java 编程时,请关注异常层次结构。
异常层次结构也分为两个分支:

  1. 从 RuntimeException 派生的异常-运行时异常:由程序员在代码里处理不当造成
    从 RuntimeException 继承的异常包括这样的
    问题如:
    在这里插入图片描述
    在这里插入图片描述

  2. 其他异常:由外部原因造成
    不从 RuntimeException 继承的异常包括
    在这里插入图片描述
    在这里插入图片描述

异常分类-从异常处理机制的角度:异常被谁check?——编译器、程序员

在这里插入图片描述

Checked Exceptions

Checked Exceptions:每个调用者都应该注意的错误并处理
必须被捕获或传播否则程序将无法编译(编译器检查您是否为所有检查的异常提供异常处理程序)
在这里插入图片描述
例子
在这里插入图片描述
在这里插入图片描述

发生异常时

– 您必须捕获并处理异常,或者通过声明您的方法抛出该异常来告诉编译器您无法处理它,
– 然后使用您的方法的代码不得不处理该异常(如果无法处理,可以选择声明它抛出异常)。
– 编译器将检查我们是否完成了两件事之一(捕获或声明)

Unchecked Exceptions

Unchecked exception: Programming error, other unrecoverable failure (Error + RuntimeException)不需要(但是你也可以catch)在编译的时候用try…catch等机制处理
在这里插入图片描述
例子
在这里插入图片描述
在这里插入图片描述

发生异常时

编译器不检查错误和运行时异常
– 错误表示应用程序外部发生的情况,例如系统崩溃。 运行时异常通常是由于应用程序逻辑中的错误而发生的。
– 在这些情况下你不能做任何事情,但必须重新编写你的程序代码。 所以编译器不会检查这些。
– 这些运行时异常将在开发和测试中发现
时期。 然后我们必须重构我们的代码来消除这些错误。

对比

在这里插入图片描述

选择哪种异常?

当要决定是采用checked exception还是unchecked exception的时候,问一个问题:“如果这种异常一旦抛出,client会做怎样的补救?在这里插入图片描述
在这里插入图片描述
– 不要创建没有意义的异常,client应该从checked exception中获取更有价值
的信息(案发现场具体是什么样子),利用异常返回的信息来明确操作失败的
原因。
– 如果client仅仅想看到异常信息,可以简单抛出一个unchecked exception
1.错误可预料,但无法预防,但可以有手段从中恢复,此时使用checked
2.如果做不到这一点,则使用unchecked exception
不可预防:脱离了你的程序的控制范围

可合理的恢复

告诉调用者预测他们无法恢复的异常是没有意义的。
– 如果用户尝试从不存在的文件中读取,调用者可以提示他们输入新的文件名。
– 另一方面,如果方法由于编程错误(无效的方法参数或错误的方法实现)而失败,则应用程序无法在执行过程中解决问题。
– 它可以做的最好的事情是记录问题并等待开发人员稍后修复它

– 如果读文件的时候发现文件不存在了,可以让用户选择其他文件;但是如果
调用某方法时传入了错误的参数,则无论如何都无法在不中止执行的前提下

进行恢复。
除非您抛出的异常满足上述所有条件条件否则它应该使用Unchecked Exception.

总结

Summary
– Checked exception应该让客户端从中得到丰富的信息,以做出相应的处理。
– 要想让代码更加易读,倾向于用unchecked exception来处理程序中的错误

继承中的异常

1.如果父类型中的方法没有抛出异常,那么子类型中的方法必须捕获所有的checked exception
2.子类型方法中不能抛出比父类型方法更多的异常!

Assertions

静态检查:通过在编译时捕获它们来消除许多错误。
– 动态检查:Java 使数组溢出错误不可能通过动态捕捉它们。 如果您尝试使用超出数组或列表边界的索引,Java 会自动产生错误。 —
未经检查的异常/运行时错误
– 不可变性:不可变类型是其值永远不能
创建后更改。
– 不可变值:通过 final,可以分配一次但永远不会
重新分配。
– 不可变引用:通过final,这使得引用不可重新分配,但引用指向的对象可能是可变的或不可变的

何时使用

断言:在开发阶段的代码中嵌入,检验某些“假设”是否成立。若成立,表明程序运行正常,否则表明存在错误。
断言即是对代码中程序员所做假设的文档化,也不会影响运行时性能(在实际使用时,assertion都会被disabled)

防御式编程Defensive Programming

Protecting Programs From Invalid Inputs

对来自外部的数据源要仔细检查,例如:文件、网络数据、用户输入等
对每个函数的输入参数合法性要做仔细检查,并决定如何处理非法输入

Barricade 设置路障

类的public方法接收到的外部数据都应被认为是dirty的,需要处理干净再传递到private方法——隔离舱
“隔离舱”外部的函数应使用异常处理,“隔离舱”内的函数应使用断言。

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



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

相关文章

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