Go语言中Panic和Recover函数是如何影响函数返回值的?
panic和recover导致的输出结果
以下程序中,为什么最终输出为0?
package main import( "fmt" "errors" ) func foo(){ panic(errors.new("bug")) return } func test()(result int){ defer func(){ if r := recover(); r!= nil{ err := r.(error) fmt.println("catch error", err) // catch error bug } }() foo() return 100 } func main(){ fmt.println(test()) // 0 }
回答:
在go语言中,如果一个函数遇到panic异常,会立即执行其defer函数,并且在defer函数中遇到recover后会忽略异常,继续执行defer之后的代码。
在本例中,test函数返回一个int类型的值,该值在函数调用时会被初始化为0。由于在foo函数中遇到了panic异常,所以在执行defer函数时,result变量的值会被修改为100。
然而,在recover语句之前,result变量已经被置为0,所以最终输出的结果仍为0。
要使程序输出100,可以将defer函数中的:
fmt.println("catch error", err)
修改为:
fmt.Println("catch error", err) result = 100
以上就是Go语言中Panic和Recover函数是如何影响函数返回值的?的详细内容,更多请关注其它相关文章!