golang變數作用域問題 避免使用全域性變數

2021-09-14 04:13:50 字數 1148 閱讀 2204

最近遇到了乙個變數作用域的問題,乙個比較低階的問題,可能作為乙個熟手不應該犯這樣的低階錯誤,但是golang的語法特點可能讓你稍微不注意就踩坑,嘿嘿。

全域性變數的作用域是整個包,區域性變數的作用域是該變數所在的花括號內,這是乙個很基礎的問題。我們通常會使用golang的乙個語法糖:=來給變數賦值,這種方式可以節省掉我們定義變數的**,讓**變的更加簡潔,但是如果你定義了乙個全域性變數,又不小心用:=來給它賦值,就會出現一些問題。

看下面的**,定義了乙個全域性變數t,我想在init()中給他賦值為2,然後在main中使用它。

var t int

func init()

fmt.println("init:", t)

}func main()

輸出:

init: 2

main: 0

執行之後,在init和main中列印出了不一樣的數字,為什麼會不一樣呢,可能你仔細一看就知道原因了。很簡單,init中的t是用:=生成的,所以t是區域性變數,在init函式中覆蓋了全域性變數t。全域性變數t並沒有被賦值,它還是原來的0值。

我本想在init中給全域性變數t賦值的,卻不小心用:=建立了乙個區域性變數導致全域性變數t沒有賦值成功,犯了乙個低階錯誤。

知道原因之後就容易解決了,我不使用:=就可以了。**如下:

var t int

func init()

fmt.println("init:", t)

}func main()

輸出:

init: 2

main: 2

沒有使用:=之後,init中的t就是全域性變數t,給全域性變數t賦值為2,main中自然輸出的就是2,實現了我最初的目的。

這個問題很簡單很低階,但是可能乙個golang熟手,在**遠比demo要複雜的多的實際專案中,不經意間就可能會犯下這樣的錯誤。

這個問題很難保證說下次一定不會出現的,除非你徹底不用全域性變數或者徹底不用:=這樣的語法糖。我的建議是這樣:

golang變數作用域問題 避免使用全域性變數

最近遇到了乙個變數作用域的問題,乙個比較低階的問題,可能作為乙個熟手不應該犯這樣的低階錯誤,但是golang的語法特點可能讓你稍微不注意就踩坑,嘿嘿。全域性變數的作用域是整個包,區域性變數的作用域是該變數所在的花括號內,這是乙個很基礎的問題。我們通常會使用golang的乙個語法糖 來給變數賦值,這種...

變數作用域問題

2018 04 09 首先一定要明白乙個問題,那就是你py程式裡面的變數作用域問題。因為你程式是工作在乙個分布式機器上的,那麼這些個資料就會分布在不同的機器上,或者說container上。要明確spark的工作架構,各個不同的工作身份。那麼乙個變數他是不是在不同的機器執行,他是不是最後會彙總到我們的...

變數的作用域問題

變數的作用域和列表 全域性 在函式外部定義,在整個全域性範圍有效 區域性 在函式內部定義,區域性範圍使用 a1 100 def func print a1 print this is func a2 99 print a2 print a1 func print a2 不能訪問區域性變數 100 1...