根据Go参考,有两种声明变量的方法
Variable_declarations(格式为var count = 0
或var count int
)
和
Short_variable_declarations(格式为count := 0
)
我发现决定使用哪一个是非常令人困惑的.
我所知道的差异(到现在为止)是:
count := 0
在函数范围内使用格式.count := 0
可以 在多变量简短声明中重新声明.但就我所知,他们的行为确实相同.在参考文献中它还说:
它(
count:=0
方式)是具有初始化表达式但没有类型的常规变量声明的简写
我的困惑是:
icz*_*cza 48
该变量声明明确指出变量的声明.该var
关键字是必需的,它是短暂的,并表示所做的事情(在文件级别排除一切有评论开始与关键字,例如package
,import
,const
,type
,var
,func
).与任何其他块一样,变量声明可以按如下方式分组:
var (
count int
sum float64
)
Run Code Online (Sandbox Code Playgroud)
使用Short变量声明不能这样做.您也可以使用变量声明而不指定初始值,在这种情况下,每个变量的类型都为零.Short变量声明不允许这样做,您必须指定初始值.
Go的指导设计原则之一是使语法清晰.许多语句需要或很方便,他们允许声明局部变量,这将是只适用于诸如语句体for
,if
,switch
等为了使语法更清洁和更短的,短变量声明在这些情况下,合理的,它是unambigous他们做什么.
for idx, value := range array {
// Do something with index and value
}
if num := runtime.NumCPU(); num > 1 {
fmt.Println("Multicore CPU, cores:", num)
}
Run Code Online (Sandbox Code Playgroud)
另一个区别:重新声明
引用语言规范:
与常规变量声明不同,短变量声明可以重新声明变量,前提是它们最初在具有相同类型的同一块中最初声明,并且至少有一个非空变量是新的.因此,重新声明只能出现在多变量简短声明中.重新声明不会引入新变量; 它只是为原始分配一个新值.
这个也很方便.假设您想要进行适当的错误处理,可以重用一个err
变量,因为很可能您只需要它来检查上一次函数调用期间是否有任何错误:
var name = "myfile.txt"
fi, err := os.Stat(name) // fi and err both first declared
if err != nil {
log.Fatal(err)
}
fmt.Println(name, fi.Size(), "bytes")
data, err := ioutil.ReadFile(name) // data is new but err already exists
// so just a new value is assigned to err
if err != nil {
log.Fatal(err)
}
// Do something with data
Run Code Online (Sandbox Code Playgroud)