defer+recover机制处理错误

本文介绍了Go语言中如何使用defer和recover机制优雅地处理错误,通过示例展示了在除法运算中如何捕获并处理 panic。同时,讲解了如何自定义错误,使用errors包创建并返回错误信息。当发生错误时,程序不会立即崩溃,而是能够按照预期执行后续逻辑。
摘要由CSDN通过智能技术生成

defer+recover机制处理错误

Go中追求代码优雅,引入机制:defer+recover机制处理错误

内置函数recover:

package main

import "fmt"

func main() {
	test()
	fmt.Println("上面的除法操作执行成功。。。")
	fmt.Println("正常执行下面的逻辑。。。")
}

func test() {
	// 利用defer+ recover来噗或错误: defer后加上匿名函数的调用
	defer func() {
		// 调用recover内置函数,可以捕获错误:
		err := recover()
		// 如果没有捕获错误,返回值为零值:nil
		if err != nil {
			fmt.Println("错误已经捕获")
			fmt.Println("err是:", err)
		}
	}()
	num1 := 10
	num2 := 0

	result := num1 / num2
	fmt.Println(result)
}
 自定义错误:

package main

import (
	// 自定错误 : 需要调用errors包下的New函数:函数返回error类型
	"errors"
	"fmt"
)

func main() {
	err := data()
	if err != nil {
		fmt.Println("自定义错误:", err)
		/*
			内置函数panic停止后当前Go程序的正常执行,当函数调用调用panic,当上面函数中的derfer的所有函数陷入后执行后,
			函数返回给其调用者 G如同F一样行动,层层返回,直到改go程序中所有函数都按相反的顺序停止执行之后,程序终止,而错误情况会被报告。
			包括引发该恐慌的实参值,词终止序列称为恐慌过程。
		*/
		panic(err)
	}
	fmt.Println("上面的除法操作执行成功。。。")
	fmt.Println("正常执行下面的逻辑。。。")
}

func data() (err error) {
	num3 := 10
	num4 := 0
	if num4 == 0 {
		// 抛出自定义错误:
		return errors.New("除数不能为0哈!!!!")
	} else {
		// 如果除数不为0,那么正常执行就可以了
		result := num3 / num4
		fmt.Println(result)

		// 如果没有错误,返回零值:
		return nil
	}

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值