轻松地按字母顺序获取地图中的键

mar*_*ter 40 sorting map go

在Go中,按字母顺序排列地图中按键的最简单方法是什么?这是我能做到的最短路:

package main

import "container/vector"
import "fmt"
import "sort"

func main() {
    m := map[string]string {"b":"15", "z":"123123", "x":"sdf", "a":"12"}
    var keys vector.StringVector;
    for k,_ := range ( m ) {
            keys.Push(k)
    }
    sort.Sort( &keys )
    fmt.Printf("%v\n", keys)
}
Run Code Online (Sandbox Code Playgroud)

pet*_*rSO 53

您正在使用StringVector对字符串数组进行排序.为了最小化开销,您可以对字符串数组进行排序.

package main

import (
    "fmt"
    "sort"
)

func main() {
    m := map[string]string{"b": "15", "z": "123123", "x": "sdf", "a": "12"}
    mk := make([]string, len(m))
    i := 0
    for k, _ := range m {
        mk[i] = k
        i++
    }
    sort.Strings(mk)
    fmt.Println(mk)
}
Run Code Online (Sandbox Code Playgroud)

输出:

[a b x z]
Run Code Online (Sandbox Code Playgroud)

  • `SortStrings`函数似乎在当前(2012年3月)Go中消失了.现在似乎只是`Strings`(即`sort.Strings(mk)`) (7认同)

Igo*_*kov 13

那将是最优雅的方法:

package main

import (
    "fmt"
    "sort"
)

func main() {
    m := map[string]string{"b": "15", "z": "123123", "x": "sdf", "a": "12"}
    keys := make([]string, 0, len(m))
    for key := range m {
        keys = append(keys, key)
    }
    sort.Strings(keys)
    fmt.Println(keys)
}
Run Code Online (Sandbox Code Playgroud)

  • 你应该把讽刺的东西放得更厚一些.一些可怜的闷棍读书可能会同意. (3认同)
  • BenchmarkFirst-4 5000000 367 ns/op 96 B/op 2 allocs/op BenchmarkSecond-4 5000000 352 ns/op 96 B/op 2 allocs/op PASS ok slice 4.383s (2认同)