初始化全局错误变量时,对于同一包中的函数来说,它可能看起来没有变化。这种差异源于对变量作用域的误解。
在第一个示例中,您使用 := 在主函数中初始化 f 和 loadErr:
func main() { f, loadErr := os.Open("asdasd") if loadErr != nil { checkErr() } if f != nil { fmt.Println(f.Name()) } }
这一行为 f 和 loadErr 创建一个新的局部变量。它不会修改函数外部定义的全局变量。因此,当您调用 checkErr() 时,loadErr 仍然为 nil,因为它尚未在主函数范围内的任何位置设置。
在第二个示例中,您使用 = 将 loadErr 的值设置为 os.Open() 返回的错误:
func main() { _, err := os.Open("asdasd") loadErr = err if loadErr != nil { checkErr() } }
通过使用 =,您正在显式分配局部 err 变量的值到全局 loadErr 变量。这允许函数 checkErr() 访问修改后的全局变量并触发恐慌。
为了防止无意中创建遮蔽全局变量的局部变量,声明全局变量非常重要在赋值之前明确地指定。在第一个示例中,您可以通过移动其定义将 loadErr 声明为主函数外部的全局变量:
var loadErr error func main() { _, loadErr = os.Open("asdasd") if loadErr != nil { checkErr() } if f != nil { fmt.Println(f.Name()) } }
这确保了全局 loadErr 变量在整个程序中可访问和更新。
以上是为什么我的全局错误变量在 Go 中初始化后不会崩溃?的详细内容。更多信息请关注PHP中文网其他相关文章!