众所周知,go的map是无序的,我们在遍历map的时候经常会出现各种问题,现在封装一个函数,用于排序后遍历使用
package main
import (
"fmt"
"sort"
)
func main() {
myMap:=make(map[string]interface{})
myMap["e"]="eeee"
myMap["a"]="aaaa"
myMap["c"]="cccc"
myMap["d"]="dddd"
myMap["b"]="bbbb"
fmt.Printf("data=====%v\n",myMap)
fmt.Println(myMap)
MapSortFor(myMap, func(key string, value interface{}) {
fmt.Println(key,value,"========")
})
}
func MapSortFor(data map[string]interface{},callback func(string,interface{})) {
var arr []string
for k,_:=range data{
arr=append(arr,k)
}
sort.Strings(arr)
for _,v:=range arr{
callback(v,data[v])
}
}
运行结果:
data=====map[a:aaaa b:bbbb c:cccc d:dddd e:eeee]
map[a:aaaa b:bbbb c:cccc d:dddd e:eeee]
a aaaa ========
b bbbb ========
c cccc ========
d dddd ========
e eeee ========
通过一个简单的案例给展示处理,其中map类型可以根据需要自行调整,原本想封装的通用所有类型,考虑类型断言性能问题,感觉还是分开封装好些
该博客介绍了在Go语言中如何对无序的map进行排序以便遍历。作者提供了一个名为`MapSortFor`的函数,该函数接受一个map和一个回调函数作为参数,首先将map的键转换为字符串切片并排序,然后按照排序后的键遍历map并调用回调函数打印键值对。示例展示了如何创建一个map并使用`MapSortFor`进行排序遍历。

1770

被折叠的 条评论
为什么被折叠?



