了解 Go 的紧急恢复中的局部变量赋值
Go 中的紧急恢复允许您优雅地处理运行时错误,但会出现一个常见的误解在恢复函数中使用局部变量时。
命名返回值紧急恢复
处理命名返回值时,恢复函数可以在这些变量被调用之前访问它们。回来了。这使您可以在 defer 函数中为它们赋值:
<code class="go">func foo() (result int, err error) { defer func() { if e := recover(); e != nil { result = -1 err = errors.New(e.(string)) } }() bar() result = 100 err = nil return }</code>
紧急恢复中的局部变量赋值
但是,当使用具有未命名返回值的局部变量时,这种行为有所不同。局部变量在堆栈上创建,并在进入函数时用零值进行初始化。如果在分配之前发生恐慌,它们将保留零值。
<code class="go">func foo() (int, error) { var result int var err error defer func() { if e := recover(); e != nil { result = -1 err = errors.New(e.(string)) } }() bar() result = 100 err = nil return result, err }</code>
在此示例中,result 和 err 分别初始化为 0 和 nil。当在进行任何分配之前发生恐慌时,将返回这些零值。因此,输出将是:
result: 0
关键区别
命名返回值被视为命名变量,允许 defer 函数直接修改它们。另一方面,局部变量存储在堆栈上,并且在分配之前不能被 defer 函数访问。
结论
当从恐慌中恢复时局部变量,理解局部变量在被赋值之前不会被初始化是至关重要的。因此,如果在赋值之前发生恐慌,它们将保留零值并影响返回值。
以上是局部变量在 Go 的紧急恢复中如何表现?的详细内容。更多信息请关注PHP中文网其他相关文章!