场景

我们来看下面这段代码,你认为它的输出结果会是什么?

func main() {
  m := map[int]string{
    1: "one",
    2: "two",
    3: "three",
    4: "four"}
    for k, v := range m {
     fmt.Println(k, v)
    }
}

预期的输出结果

1 one
2 two
3 three
4 four
我们通常认为遍历都是有顺序的输出的

但在Go语言中,遍历map不保证顺序

实际可能的输出结果

4 four
1 one
2 two
3 three

3 three
4 four
1 one
2 two

2 two
3 three
4 four
1 one


1 one
2 two
3 three
4 four

如何保证遍历map固定顺序输出?

方法一:运用切片

func slove(m map[int]string) {
  var s []int
  for k := range m {
    s = append(s, k)
  }

  sort.Ints(s) //升序
  // sort.Sort(sort.Reverse(sort.IntSlice(s))) //降序
  for _, v := range s {
    fmt.Println(v)
    fmt.Println(m[v])
  }
}

方法二:第三方包

https://github.com/elliotchance/orderedmap

References