用map实现slice去重最常用也最稳妥,核心是将元素作为key存入mapinterface{}struct{},再遍历构建新slice;注意元素需可比较,结构体不可含slice/map/func,该方法保持顺序但不并发安全。用 map 实现 slice 去重最常用也最稳妥Go 没有内置去重函数,map 是最直接、可读性好、性能可控的方案。核心思路是把元素当 key 存进 mapinterface{}struct{}(或具体类型),再遍历原 slice 构建新 slice。常见错误是用 mapstringbool 存字符串却忽略结构体、指针等不可比较类型;或者用 mapstringint 误以为要计数------去重不需要值,用 struct{} 更省内存。基础示例(字符串 slice):items := \[\]string{"a", "b", "a", "c"}seen := make(mapstringstruct{})var result \[\]stringfor _, item := range items { if _, exists := seenitem; !exists { seenitem = struct{}{} result = append(result, item) }}如果元素是结构体,必须确保它所有字段都可比较(不能含 slice、map、func);否则得转成 JSON 字符串或自定义哈希键注意:该方法保持原始顺序,但不保证并发安全;多 goroutine 写同一 map 必须加锁或改用 sync.Map(仅适合读多写少场景)对 \[\]int 等基本类型,可考虑 sort + 双指针减少内存分配当 slice 很大且允许重排顺序时,先排序再双指针去重比建 map 更省内存,尤其 \[\]int、\[\]int64 这类小对象。容易踩的坑是忘记排序------双指针依赖相邻重复,未排序结果完全错误;还有人用 sort.Ints() 后直接修改原 slice,导致上游逻辑异常。立即学习"go语言免费学习笔记(深入)"; 文心快码 文心快码(Comate)是百度推出的一款AI辅助编程工具
相关推荐
金銀銅鐵15 小时前
[Python] 从《千字文》中随机挑选汉字cup1120 小时前
[技术复盘] Windows Python 打包实战:Nuitka 环境踩坑总结与 CI 自动化构建全指南aqi001 天前
15天学会AI应用开发(七)有了大模型为什么还要引入RAG金銀銅鐵1 天前
用 Python 实现 Take-Away 游戏copyer_xyf1 天前
Agent 流程编排copyer_xyf1 天前
Agent RAGcopyer_xyf1 天前
【RAG】向量数据库:milvuscopyer_xyf1 天前
Agent 记忆管理星云穿梭2 天前
用Python写一个带图形界面的学生管理系统——完整教程