你能有一张没有go价值的地图吗?
来源:stackoverflow
时间:2024-03-25 16:51:33 404浏览 收藏
在 Go 中,地图中的每个键都需要指定一个值。使用空结构 `struct{}` 作为值可以避免存储实际数据,仅存储键。这种方法可以节省空间,但也会导致更复杂的语法和键查找。相比之下,使用 `map[int]bool` 更加直接,内存开销也更低。对于大型映射,如果内存受限,可以使用 `struct{}`;否则,建议使用 `map[int]bool`。
我问是因为我喜欢地图不允许多个键。我知道您可以执行如下操作,其中您的值是布尔值或空结构,但是有没有办法绕过为您的键指定任何值?必须指定空结构有什么好处吗?
相关问题,但重点关注仅附加唯一值。
type N struct {} func tengoQueCagar() { var map_almost_empty_value1 = map[int]bool{0:true,1:false} var map_almost_empty_value2 = map[int]struct{}{0:struct{}{},1:struct{}{}} //long and seems like lame syntax... var map_almost_empty_value3 = map[int]N{0:N{},1:N{}} //shorter.. better? var map_not_possible_empty_value_2 = map[int]nil{0:nil,1:nil} // better than empty struct syntax... but not possible var map_not_possible_empty_value_2 = map[int]{0,1} // ideally possible... but not... //do something... }
解决方案
struct{}
需要 0 个字节来存储。如果您使用 struct{}
值声明地图,则您将仅存储地图键。
有一篇关于它的很好的博客文章: https://dave.cheney.net/2014/03/25/the-empty-struct
如果您想像集合一样使用映射,为其声明一个单独的类型可能会有所帮助:
type intset map[int]struct{}
并且您可以向其中添加一些方便的方法,例如:
func (i IntSet) Has(v int) bool { _, ok := i[v] return ok }
要直接回答您的问题:请参阅下文!
这种“空 struct{}
作为映射值技巧”经常出现,支持的论点始终采用“因此值不需要存储空间”的形式。
另一个自然要做的事情是使用 map[int]bool
。
如果内存确实是您的应用的一个限制(例如,因为您在映射中存储了数百万或数十亿个键),那么可以:使用 struct{}
。对于所有其他正常情况:使用 struct{}
会使此类映射文字变得尴尬,并且键查找变得更加复杂,因为您必须使用逗号-ok-变体 (if _,ok := m[k ];好的{
。
对于 bool 值,您可以执行简单的 m[k]
,这样输入量较少且更易于理解。
我个人认为使用 struct{}
作为地图值是不必要的、不成熟的、过于聪明的优化。如果您确实需要保存这几个字节,因为您的映射将包含数百万个条目,那么映射可能不是正确的数据结构:根据用例位向量、稀疏数据结构甚至概率数据结构(bloom-、cuckoo) -filters)、union-find 等可能更适合。
答案:不。在地图文字中,您必须指定每个键。 (一般经验法则:go 中没有语法糖;go 中没有聪明的快捷方式;go 中的一切都是明确的。)
终于介绍完啦!小伙伴们,这篇关于《你能有一张没有go价值的地图吗?》的介绍应该让你收获多多了吧!欢迎大家收藏或分享给更多需要学习的朋友吧~golang学习网公众号也会发布Golang相关知识,快来关注吧!
-
502 收藏
-
502 收藏
-
501 收藏
-
501 收藏
-
501 收藏
-
139 收藏
-
204 收藏
-
325 收藏
-
477 收藏
-
486 收藏
-
439 收藏
-
357 收藏
-
352 收藏
-
101 收藏
-
440 收藏
-
212 收藏
-
143 收藏
-
- 前端进阶之JavaScript设计模式
- 设计模式是开发人员在软件开发过程中面临一般问题时的解决方案,代表了最佳的实践。本课程的主打内容包括JS常见设计模式以及具体应用场景,打造一站式知识长龙服务,适合有JS基础的同学学习。
- 立即学习 542次学习
-
- GO语言核心编程课程
- 本课程采用真实案例,全面具体可落地,从理论到实践,一步一步将GO核心编程技术、编程思想、底层实现融会贯通,使学习者贴近时代脉搏,做IT互联网时代的弄潮儿。
- 立即学习 508次学习
-
- 简单聊聊mysql8与网络通信
- 如有问题加微信:Le-studyg;在课程中,我们将首先介绍MySQL8的新特性,包括性能优化、安全增强、新数据类型等,帮助学生快速熟悉MySQL8的最新功能。接着,我们将深入解析MySQL的网络通信机制,包括协议、连接管理、数据传输等,让
- 立即学习 497次学习
-
- JavaScript正则表达式基础与实战
- 在任何一门编程语言中,正则表达式,都是一项重要的知识,它提供了高效的字符串匹配与捕获机制,可以极大的简化程序设计。
- 立即学习 487次学习
-
- 从零制作响应式网站—Grid布局
- 本系列教程将展示从零制作一个假想的网络科技公司官网,分为导航,轮播,关于我们,成功案例,服务流程,团队介绍,数据部分,公司动态,底部信息等内容区块。网站整体采用CSSGrid布局,支持响应式,有流畅过渡和展现动画。
- 立即学习 484次学习