您的位置 首页 技术

golang recover后怎么返回

recover 虽然没有try catch机制,Go其实有一种类似的recover机制,功能弱了点,用法很简单: (推荐学习:go) package mainimport “fmt…

recover

虽然没有try catch机制,Go其实有一种类似的recover机制,功能弱了点,用法很简单: (推荐学习:go)

package mainimport "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函数里面每次终止的时候都会检查有没有异常产生,如果产生了我们可以处理,比如说记录日志,这样程序还可以继续执行下去。

package mainimport (        "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后怎么返回的详细内容,更多请关注24课堂在线网其它相关文章!

本文来自网络,不代表24小时课堂在线立场,转载请注明出处:https://www.24ketang.cn/16430.html

为您推荐

返回顶部