golang中的defer panic recover

大家都知道golang里的panic相当于其他语言里的throw,而recover相当于其他语言里的cacth,可是由于golang的recover机制要求必须在defer的函数里才能执行catch panic

大概意思如下


func protect(g func()) {
	defer func() {
		log.Println("done")  // Println executes normally even if there is a panic
		if x := recover(); x != nil {
			log.Printf("run time panic: %v", x)
		}
	}()
	log.Println("start")
	g()
}

这似乎跟try catch没啥区别,但是如果我们想实现一个其他语言里的如下功能时,可就不一样了


int test() {
    try {
        doSomething();
    }
    catch {
        return 1
    }
    return 2
}

显然这个函数需要能够根据有没有异常发生来返回不同的值,这怎么办呢?

其实这个问题与recover以及panic没啥关系了,这个问题纯粹属于defer的问题了,也即能不能在defer的函数里修改当前函数的返回值,答案当然是肯定的了,你只需要给返回值命名就行了


func routine() (b bool) {
	defer func() {
		err := recover()
		if err != nil {
			fmt.Printf("err found\n")
			b = true
		}
	}()
	if rand.Int()%10 == 1 {
		panic("hello")
	}
	b = false
	return
}

但是大家往深里想一下的话,就会觉得这样实现也挺坑爹的了,比如,里面有两处panic的时候,怎么办呀?当然是有办法的了,只是比较丑陋而已,这里就不举例说明了。



本文来自:CSDN博客

感谢作者:HopingWhite

查看原文:golang中的defer panic recover

郑重声明:本站内容如果来自互联网及其他传播媒体,其版权均属原媒体及文章作者所有。转载目的在于传递更多信息及用于网络分享,并不代表本站赞同其观点和对其真实性负责,也不构成任何其他建议。