本文摘自php中文网,作者(*-*)浩,侵删。

recover
虽然没有try catch机制,Go其实有一种类似的recover机制,功能弱了点,用法很简单: (推荐学习:go)
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 | package main
import "fmt"
func main() {
fmt.Printf("%d\n", cal(1, 2))
fmt.Printf("%d\n", cal(5, 2))
fmt.Printf("%d\n", cal(5, 0))
fmt.Printf("%d\n", cal(9, 2))
}
func cal(a, b int) int {
defer func() {
if err := recover(); err != nil {
fmt.Printf("%s\n", err)
}
}()
return a / b
}
|
首先,大家得理解defer的作用,简单说defer就类似于面向对象里面的析构函数,在这个函数终止的时候会执行,即使是panic导致的终止。
所以,在cal函数里面每次终止的时候都会检查有没有异常产生,如果产生了我们可以处理,比如说记录日志,这样程序还可以继续执行下去。
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 | package main
import (
"errors"
"fmt"
"math"
)
func main() {
_, err := IntFromInt64(math.MaxInt32 + 1)
if err != nil {
fmt.Println(err)
}
}
func ConvertInt64ToInt(i64 int64) int {
if math.MinInt32 <= i64 && i64 <= math.MaxInt32 {
return int(i64)
}
panic("can't convert int64 to int")
}
func IntFromInt64(i64 int64) (i int, err error) {//这里
defer func() {
if err2 := recover(); err2 != nil {
i = 0//这里
err = errors.New("ttt")//这里
}
}()
i = ConvertInt64ToInt(i64)
return i, nil
}
|
主要思想:return之前利用defer修改返回变量(提前确定为i和err)的值
以上就是golang recover后怎么返回的详细内容,更多文章请关注木庄网络博客!!
相关阅读 >>
golang开发中包的使用
golang 踩坑时间parse转换后加8小时
chaos-mesh on mips64
关于一个mongodb和golang搭伙采坑
golang单元测试怎么写
聊聊storagetapper的pipe
go中x/sync/semaphore解读
深度剖析golang sync.once源码
golang基础数据类型字符串
go后offer之路上的那些真相
更多相关阅读请进入《golang》频道 >>
老貘
一个与时俱进的Go编程知识库。
转载请注明出处:木庄网络博客 » golang recover后怎么返回