您好,欢迎访问一九零五行业门户网

golang recover后怎么返回

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后怎么返回的详细内容。
其它类似信息

推荐信息