1. 程式人生 > 其它 >關於Golang語言陣列索引的有趣現象

關於Golang語言陣列索引的有趣現象

在Twitter上看到Dave Cheney提了個pop quiz 勾起了我的好奇心,可以猜下下面這段程式碼的執行結果。

package main

import "fmt"

func main() {
	a := [...]int{5, 4: 1, 0, 2: 3, 2, 1: 4}
	fmt.Println(a)
}

go run 一下結果就出來了 但是比較有意思的是結果是

[5 4 3 2 1 0]

下面就一步步地分析是什麼情況

[number:value] 在go的陣列中代表的是在索引未number處的位置上值為value 如果索引值越界了就會重置。

5 _ _ _ _ _ index : 0, value : 5

5 _ _ _ 1 _ index : 4, value : 1

5 _ _ _ 1 0 index : 5, value : 0 因為上一個操作的元素索引為4 ([4:1])所以下一個操作的元素索引自動加1

5 _ 3 _ 1 0 index : 2, value : 3

5 _ 3 2 1 0 index : 3, value : 2 因為上一個操作的元素索引為2 ([2:3])所以下一個操作的元素索引自動加1

5 1 3 2 1 0 index : 1, value : 4

運算元組元素的順序是按照宣告時的順序,順序操作的。5 1 0 3 2 4就是按照這個順序 進行操作的。

所以如果把程式碼改一下就會報錯 比如下面的例子

package main

import "fmt"

func main() {
	a := [...]int{5, 4: 1, 0, 2: 3, 2, 1: 4, 10}
	fmt.Println(a)
}

結果

prog.go:6: duplicate index in array literal: 2
 [process exited with non-zero status]

報錯資訊是 第二個索引重複了

接著上面的分析

5 1 3 2 1 0 index : 1, value : 4 這時如果繼續操作下一個元素根據規則 索引加1

也就是 要對index : 2 的元素進行 value : 10的操作 但是之前我們已經在索引為2時賦值過了 所以就會有異常

duplicate index in array literal: 2