defer+recover机制处理错误
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
}
}
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 阿里最新开源QwQ-32B,效果媲美deepseek-r1满血版,部署成本又又又降低了!
· AI编程工具终极对决:字节Trae VS Cursor,谁才是开发者新宠?
· 开源Multi-agent AI智能体框架aevatar.ai,欢迎大家贡献代码
· Manus重磅发布:全球首款通用AI代理技术深度解析与实战指南
· 被坑几百块钱后,我竟然真的恢复了删除的微信聊天记录!