Go语言入门10(异常处理)

异常处理

panic 异常处理

​ 如果出现了panic异常,那么会停止当前函数的运行,然后会找recover()方法,如果没有的话,就会报错退出程序,如果有就会执行recover的方法体中的方法

​ 我们可以使用defer延迟处理函数来捕获panic异常,用recover()来从错误场景中恢复,必须的在defer修饰的方法中使用,不然不生效,panic抛出异常,defer具备延迟处理功能,所以最后这种兜底的活只能defer来做

// 定义一个带有panic异常的方法
func Test01(tmp int) string {
	fmt.Println("This is a test!")
	// 如果传入的参数是负数,那么就会抛出panic异常    
	if tmp <= 0 {
		panic("不能传递非正数")
	}
	return "这是一个正数"
}

func main() {
    // 使用defer + recover来兜底
	defer func() {
		err := recover()
		if err != nil {
			fmt.Println(err)
		}
	}()
	fmt.Println(Test01(-1))
    // 由于panic异常会停止当前函数运行,所以下面的输出不会被执行
	fmt.Println("异常处理之后")
}

errors 异常处理

​ Go语言有一个预先定义的 error 接口类型,同时也提供了一个包 errors,包中有一个 errorString 结构体实现了 error 接口 。任何时候当你需要一个新的错误类型,都可以用 errors 包的errors.New函数接收合适的错误信息来创建

​ error异常不会中断程序运行,所以不需要defer 和 recover 兜底

// 返回值要声明error类型
func Test02(tmp int) (res string, err error) {
	if tmp > 0 {
        // 如果正常输出,也需要返回nil
		return "这是正数", nil
	} else {
        // 使用函数创建error异常
		err := errors.New("不能传递非正数!")
		return "", err
	}
}

func main() {
	res, err := Test02(34)
	if err != nil {
		fmt.Println("出现错误:", err)
	} else {
		fmt.Println("传参正确:", res)
	}
    // error异常不会中断运行,下面的输出会被执行
    fmt.Println("异常处理之后")
}

自定义异常

// 新建一个异常结构体,用来存储参数
type customException struct {
	contain string
}

// 实现Error接口
func (tmp *customException) Error() string {
	err := fmt.Sprintf("这是一个自定义错误: %s", tmp.contain)
	return err
}

func Test03(tmp int) (res string, err error) {
	if tmp < 0 {
		panic(&customException{"不能传入负数"})
	} else if tmp == 0 {
		err = &customException{"不能传入0"}
		return
	} else {
		return "这是一个正数", nil
	}
}

func main() {
	defer func() {
		err := recover()
		if err != nil {
			fmt.Println(err)
		}
	}()
	res, err := Test03(-1)
	if err != nil {
		fmt.Println("出现错误:", err)
	} else {
		fmt.Println("传参正确:", res)
	}
	fmt.Println("异常处理之后")
}

热门相关:超武穿梭   网游之逆天飞扬   大神你人设崩了   仗剑高歌   重生之至尊千金