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
以上就是Go语言中Panic和Recover函数是如何影响函数返回值的?的详细内容,更多请关注php中文网其它相关文章!
每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号