Go map排序的实现示例
更新时间:2023年12月25日 10:21:24 作者:metabit
map默认是无序的,不管是按照key还是按照value默认都不排序,本文主要介绍了Go map排序的实现示例,具有一定的参考价值,感兴趣的可以了解一下
1. 将key 或 value 单独组成其类型的切片或数组,进行排序
package main import ( "fmt" "sort" ) func main() { table := map[string]string{ "hello": "hello", "world": "world", "a": "a", "b": "b", "c": "c", "d": "d", } var keys, values []string for k, v := range table { keys = append(keys, k) values = append(values, v) } sort.Slice(keys, func(i, j int) bool { if keys[i] < keys[j] { //keys[i], keys[j] = keys[j], keys[i] values[i], values[j] = values[j], values[i] return true } return false }) fmt.Println(keys) fmt.Println(values) }
可以根据有序的key,找到对应的value
for _, key := range keys { fmt.Println(table[key]) }
2. 将key,value放入结构体,对结构体切片排序,既可以对key排序,又可以对value排序
type Entity struct { K string V string } table := map[string]string{ "hello": "hello", "world": "world", "a": "a", "b": "b", "c": "c", "d": "d", } var entities []Entity for k, v := range table { entities = append(entities, Entity{k, v}) } sort.Slice(entities, func(i, j int) bool { return entities[i].K < entities[j].K }) fmt.Println(entities)
到此这篇关于Go map排序的实现示例的文章就介绍到这了,更多相关GO map排序内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!
相关文章
golang微服务框架kratos实现Socket.IO服务的方法
本文主要介绍了golang微服务框架kratos实现Socket.IO服务的方法,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧2023-06-06go time.After优化后性能提升34%内存减少67%
这篇文章主要介绍了go语言time.After优化后性能提升34%内存减少67%实例分析,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪2023-02-02
最新评论