go学习总结(十三)异常处理

所谓的异常:当GO检测到一个错误时,程序就无法继续执行了,反而出现了一些错误的提示,这就是所谓的"异常"。
所以为了保证程序的健壮性,要对异常的信息进行处理。例如,如下程序,定义一个函数实现整除操作,这个程序对大家来说已经很简单了,实现如下:
在这里插入图片描述
但是,大家仔细考虑一下,该方法是否有问题?
如果b的值为0,会出现什么情况?
程序会出现以下的异常信息:
在这里插入图片描述
并且整个程序停止运行。
那么出现这种情况,应该怎样进行处理呢?这时就要用到异常处理方法的内容。

error接口

Go语言引入了一个关于错误处理的标准模式,即error接口,它是Go语言内建的接口类型,该接口的定义如下:
在这里插入图片描述
Go语言的标准库代码包errors为用户提供如下方法:
在这里插入图片描述
通过以上代码,可以发现error接口的使用是非常简单的(error是一个接口,该接口只声明了一个方法Error(),返回值是string类型,用以描述错误
)。下面看一下基本使用,
首先导包:
在这里插入图片描述
然后调用其对应的方法:
在这里插入图片描述
当然fmt包中也封装了一个专门输出错误信息的方法,如下所示:
在这里插入图片描述
了解完基本的语法以后,接下来使用error接口解决Test( )函数被0整除的问题,如下所示:
在这里插入图片描述
在Test( )函数中,判断变量b的取值,如果有误,返回错误信息。并且在main( )中接收返回的错误信息,并打印出来。
这种用法是非常常见的,例如,后面讲解到文件操作时,涉及到文件的打开,如下:
在这里插入图片描述
在打开文件时,如果文件不存在,或者文件在磁盘上存储的路径写错了,都会出现异常,这时可以使用error记录相应的错误信息。

panic函数

error返回的是一般性的错误,但是panic函数返回的是让程序崩溃的错误。
也就是当遇到不可恢复的错误状态的时候,如数组访问越界、空指针引用等,这些运行时错误会引起painc异常,在一般情况下,我们不应通过调用panic函数来报告普通的错误,而应该只把它作为报告致命错误的一种方式。当某些不应该发生的场景发生时,我们就应该调用panic。
一般而言,当panic异常发生时,程序会中断运行。随后,程序崩溃并输出日志信息。日志信息包括panic value和函数调用的堆栈跟踪信息。
当然,如果直接调用内置的panic函数也会引发panic异常;panic函数接受任何值作为参数。
下面给大家演示一下,直接调用panic函数,是否会导致程序的崩溃。
在这里插入图片描述
错误信息如下:
在这里插入图片描述
所以,我们在实际的开发过程中并不会直接调用panic( )函数,但是当我们编程的程序遇到致命错误时,系统会自动调用该函数来终止整个程序的运行,也就是系统内置了panic函数。
下面给大家演示一个数组下标越界的问题:
在这里插入图片描述
错误信息如下:
在这里插入图片描述
通过观察错误信息,发现确实是panic异常,导致了整个程序崩溃。

延迟调用defer

(1)defer基本使用
函数定义完成后,只有调用函数才能够执行,并且一经调用立即执行。例如:
在这里插入图片描述
先输出“gt”,然后再输出“gt2”
但是关键字 defer ⽤于延迟一个函数(或者当前所创建的匿名函数)的执行。注意,defer语句只能出现在函数的内部。
基本用法如下:
在这里插入图片描述
以上两行代码,输出的结果为,先输出“gt2”,然后输出”gt”.
defer的应用场景:文件操作,先打开文件,执行读写操作,最后关闭文件。为了保证文件的关闭能够正确执行,可以使用defer.
大家可以先看一下文件操作的伪代码,来体会一下关于defer的场景,关于文件操作,我们后面会详细的讲解。
(2)defer执行顺序
先看如下程序执行结果是:
在这里插入图片描述
执行的结果是:
在这里插入图片描述
总结:如果一个函数中有多个defer语句,它们会以LIFO(后进先出)的顺序执行。
如下程序执行的结果:
在这里插入图片描述
执行结果:
在这里插入图片描述
即使函数或某个延迟调用发生错误,这些调用依旧会被执⾏

(3)defer与匿名函数结合使用
我们先看以下程序的执行结果:
在这里插入图片描述
执行的结果如下:
在这里插入图片描述
前面讲解过,defer会延迟函数的执行,虽然立即调用了匿名函数,但是该匿名函数不会执行,等整个main( )函数结束之前在去调用执行匿名函数,所以输出结果如上所示。

现在将程序做如下修改:
在这里插入图片描述
该程序的执行结果如下:
在这里插入图片描述
从执行结果上分析,由于匿名函数前面加上了defer所以,匿名函数没有立即执行。但是问题是,程序从上开始执行当执行到匿名函数时,虽然没有立即调用执行匿名函数,但是已经完成了参数的传递。

recover

运行时panic异常一旦被引发就会导致程序崩溃。这当然不是我们愿意看到的,因为谁也不能保证程序不会发生任何运行时错误。
Go语言为我们提供了专用于“拦截”运行时panic的内建函数——recover。它可以是当前的程序从运行时panic的状态中恢复并重新获得流程控制权。
语法如下:
在这里插入图片描述
注意:recover只有在defer调用的函数中有效。
示例如下:
在这里插入图片描述
以上程序的运行结果如下:
在这里插入图片描述
通过以上程序,我们发现虽然TestB( )函数会导致整个应用程序崩溃,但是由于在该函数中调用了recover( )函数,所以整个函数并没有崩溃。虽然程序没有崩溃,但是我们也没有看到任何的提示信息,那么怎样才能够看到相应的提示信息呢?
可以直接打印recover( )函数的返回结果,如下所示:
在这里插入图片描述
输出结果如下:
在这里插入图片描述
从输出结果发现,确实打印出了相应的错误信息。
但是,如果程序没有出错,也就是数组下标没有越界,会出现什么情况呢?
在这里插入图片描述
这时输出的是空,但是我们希望程序没有错误的时候,不输出任何内容。
所以,程序修改如下:
在这里插入图片描述
通过以上代码,发现其实就是加了一层判断。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

vegetablesssss

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值