
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之后的代码。
立即学习“go语言免费学习笔记(深入)”;
在本例中,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










