go map排序执行封装

该博客介绍了在Go语言中如何对无序的map进行排序以便遍历。作者提供了一个名为`MapSortFor`的函数,该函数接受一个map和一个回调函数作为参数,首先将map的键转换为字符串切片并排序,然后按照排序后的键遍历map并调用回调函数打印键值对。示例展示了如何创建一个map并使用`MapSortFor`进行排序遍历。

众所周知,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类型可以根据需要自行调整,原本想封装的通用所有类型,考虑类型断言性能问题,感觉还是分开封装好些

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Venvis

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值