原文地址:http://www.niu12.com/article/14 panic知识点 package main import ( "fmt" "github.com/pkg/errors" ) func main() { outerFunc() fmt.Println(1) } func outerFunc() { innerFunc() } func innerFunc() { panic(errors.New("An intended fatal error")) } 当调用innerFunc 函数中的panic函数后,innerFunc 的执行会被停止。 紧接着,流程控制权会交回给调用方outerFunc函数。 然后, outerFunc函数的执行也将被停止。运行时恐慌就这样沿着调用栈反方向进行传播, 直至到达当前goroutine的调用栈的最顶层。-旦达到顶层,就意味着该goroutine调用栈 中所有函数的执行都已经被停止了,程序已经崩溃。 GO运行时系统也会调用panic() 函数 recover 运行时恐慌一旦被引发,就会向调用方传播直至程序崩溃。 Go 提供了专用于“拦截” 运行时恐慌的内建函数 recover ,它可以使气前的程序从恐慌状态中恢复并重新获 得流程控制权。 recover 函数被调川后,会返回一个 interfaoe { }类型的结果、 如果当时的程序正处于运行时恐慌的状态,那么这个结果就会是非 nil 的。 func innerFunc() { defer func() { if p := recover(); p != nil { fmt.Printf("Recovered panic:%s\n", p) } }() panic(errors.New("An intended fatal error")) } 将defer 匿名函数放在函数体的开始处,可以有效防止该函数及其下层调用中的代码引发运行时恐慌 口可以把运行时恐慌的携带值转换为error类型值,并当作常规结果返回给调用方。 这样既阻止了恐慌的扩散,又传递了引起恐慌的原因。 口检查运行时恐慌携带值的类型,并根据类型做不同的后续动作,这样可以精确地 控制程序的错误处理行为。
原文地址:https://www.cnblogs.com/zhouqi666/p/10284801.html
时间: 2024-10-30 02:49:39