golang recover后怎么返回


本文摘自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》频道 >>




打赏

取消

感谢您的支持,我会继续努力的!

扫码支持
扫码打赏,您说多少就多少

打开支付宝扫一扫,即可进行扫码打赏哦

分享从这里开始,精彩与您同在

评论

管理员已关闭评论功能...