站长资讯网
最全最丰富的资讯网站

golang recover后怎么返回

golang recover后怎么返回

recover

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

package main import "fmt" func main() { fmt.Printf("%dn", cal(1, 2)) fmt.Printf("%dn", cal(5, 2)) fmt.Printf("%dn", cal(5, 0)) fmt.Printf("%dn", cal(9, 2)) } func cal(a, b int) int { defer func() { if err := recover(); err != nil { fmt.Printf("%sn", err) } }() return a / b }

首先,大家得理解defer的作用,简单说defer就类似于面向对象里面的析构函数,在这个函数终止的时候会执行,即使是panic导致的终止。

所以,在cal函数里面每次终止的时候都会检查有没有异常产生,如果产生了我们可以处理,比如说记录日志,这样程序还可以继续执行下去。

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)的值

赞(0)
分享到: 更多 (0)
网站地图   沪ICP备18035694号-2    沪公网安备31011702889846号