首页 > 后端开发 > Golang > 为什么Go中全局错误变量初始化失败?

为什么Go中全局错误变量初始化失败?

Barbara Streisand
发布: 2024-12-14 14:51:18
原创
620 人浏览过

Why Does Global Error Variable Initialization Fail in Go?

全局错误变量初始化失败

在 Go 程序中,全局初始化错误变量会带来一个特殊问题,即它在同一包中的其他功能。为了解开这个谜团,让我们深入研究一个具体的例子:

package main<p>import (</p><pre class="brush:php;toolbar:false">"os"
"fmt"
登录后复制

)

var loadErr错误

func main() {

f, loadErr := os.Open("asdasd")
if loadErr != nil {
    checkErr()
}
if f != nil {
    fmt.Println(f.Name())
}
登录后复制

}

//不会调用panic,因为loadErr为nil
func checkErr() {

if loadErr != nil {
    panic(loadErr)
}
登录后复制

}

在这种情况下,您自然会期望代码当文件无法打开时发生恐慌。然而,与预期相反,由于 loadErr 变量为零,它保持沉默。为了解决这个问题,必须做出一个关键的区别。

在 Go 中,当使用 := 运算符时,会在函数范围内创建一个新的局部变量。在本例中,行:

f, loadErr := os.Open("asdasd")

本质上构造了一个名为 loadErr 的局部变量,不同来自全局声明的变量。不幸的是,全局变量不受影响,导致 nil 值难题。

要解决此问题,必须将 := 运算符替换为标准赋值运算符 =。这确保了全局变量 loadErr 被引用并使用 os.Open() 返回的值进行初始化:

func main() {<pre class="brush:php;toolbar:false">_, loadErr = os.Open("asdasd")
登录后复制

通过进行这个细微的更改,可以正确设置全局错误变量,并且恐慌函数现在的行为如下

此外,如果您需要 os.Open() 的两个返回值,则必须事先显式声明赋值中使用的第二个变量:

var f *os .File<br>f, loadErr = os.Open("asdasd")<br>
登录后复制

以上是为什么Go中全局错误变量初始化失败?的详细内容。更多信息请关注PHP中文网其他相关文章!

来源:php.cn
本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
作者最新文章
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板