- r - 以节省内存的方式增长 data.frame
- ruby-on-rails - ruby/ruby on rails 内存泄漏检测
- android - 无法解析导入android.support.v7.app
- UNIX 域套接字与共享内存(映射文件)
我可以通过
创建一个“静态” maptype m map[int]map[int]map[int]bool
但是“键”的长度是动态的:
|---unknown len--|
m[1][2][3][4][2][0] = true
或
|---unk len--|
m[1][2][3][4] = true
如何在 Go 中创建此 map ?或者存在任何方式?
补充:分层重要
提前致谢!
最佳答案
map type :
A map is an unordered group of elements of one type, called the element type, indexed by a set of unique keys of another type, called the key type.
映射类型必须具有特定的值类型和特定的键类型。你想要的不符合这个条件:你想要一个 map ,其中的值是有时另一个 map (相同类型),有时它是一个bool
.
您的选择:
这里的想法是不要只使用一个简单的 (bool
) 值类型,而是使用一个包装器来保存您的两个潜在值:map
和简单的值(bool
):
type Value struct {
Children MapType
V bool
}
type MapType map[int]*Value
var m MapType
这基本上是 user3591723 的建议,所以我不会进一步详细说明。
这是 #1 的变体,但通过这种方式我们清楚地表明它是一棵树。
实现层次结构的最简洁的方法是使用树,其中的节点可能如下所示:
type KeyType int
type ValueType string
type Node struct {
Children map[KeyType]*Node
Value ValueType
}
这样做的好处是您可以选择值类型(在您的情况下为 bool
,但您可以将其更改为任何类型 - 我使用 string
进行演示).
为了轻松构建/管理您的树,我们可以向我们的 Node
类型添加一些方法:
func (n *Node) Add(key KeyType, v ValueType) {
if n.Children == nil {
n.Children = map[KeyType]*Node{}
}
n.Children[key] = &Node{Value: v}
}
func (n *Node) Get(keys ...KeyType) *Node {
for _, key := range keys {
n = n.Children[key]
}
return n
}
func (n *Node) Set(v ValueType, keys ...KeyType) {
n = n.Get(keys...)
n.Value = v
}
并使用它:1. 构建一棵树,2. 查询一些值,3. 更改一个值:
root := &Node{Value: "root"}
root.Add(0, "first")
root.Get(0).Add(9, "second")
root.Get(0, 9).Add(3, "third")
root.Get(0).Add(4, "fourth")
fmt.Println(root)
fmt.Println(root.Get(0, 9, 3))
fmt.Println(root.Get(0, 4))
root.Set("fourthMod", 0, 4)
fmt.Println(root.Get(0, 4))
输出(在 Go Playground 上尝试):
&{map[0:0x104382f0] root}
&{map[] third}
&{map[] fourth}
&{map[] fourthMod}
这可能令人惊讶,但可以使用递归定义在 Go 中定义具有无限或动态“深度”的 map
类型:
type X map[int]X
如其名:它是一个带有 int
键的 map
,以及与 map 本身类型相同的值。
这种递归类型的一大缺点是它不能在值类型中存储任何“有用”的数据。它只能存储“事实”是否存在与 bool
类信息相同的值(bool
类型:true
或 false
),这在极少数情况下可能就足够了,但在大多数情况下都不够。
让我们看一个构建“树”的例子:
var x X
x = map[int]X{}
x[0] = map[int]X{}
x[0][9] = map[int]X{}
x[0][9][3] = map[int]X{}
x[0][4] = map[int]X{}
fmt.Println(x)
输出:
map[0:map[9:map[3:map[]] 4:map[]]]
如果我们想测试是否存在基于一系列键的“值”,我们有两个选择:要么使用特殊的 v, ok := m[i]
索引(报告指定键的值是否存在),或测试该值是否不是 nil
,例如m[i] != nil
.
让我们看一些测试上面构建的 map 的例子:
var ok bool
_, ok = x[0][9][3]
fmt.Println("x[0][9][3] exists:", ok, "; alternative way:", x[0][9][3] != nil)
_, ok = x[0][9][4]
fmt.Println("x[0][9][4] exists:", ok, "; alternative way:", x[0][9][4] != nil)
_, ok = x[0][4]
fmt.Println("x[0][4] exists:", ok, "; alternative way:", x[0][4] != nil)
_, ok = x[0][4][9][9][9]
fmt.Println("x[0][4][9][9][9] exists:", ok, "; alternative way:", x[0][4][9][9][9] != nil)
输出:
x[0][9][3] exists: true ; alternative way: true
x[0][9][4] exists: false ; alternative way: false
x[0][4] exists: true ; alternative way: true
x[0][4][9][9][9] exists: false ; alternative way: false
在 Go Playground 上试试这些.
注意:即使 x[0][4]
是最后的“叶子”,索引更像 x[0][4][9 ][9][9]
不会导致 panic ,因为 nil
映射可以被索引并产生值类型的零值(即 nil
如果值类型是映射类型)。
关于dictionary - 戈朗 : How to create unknown (dynamic) Map length,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/34761129/
我正在尝试从一个 map 的 map 的 map 的 map 的 map 的 map 的 map 的 map 的 map 的 map 的 map 的 map 的 map 的 map 的 map 的 m
我是 Haskell 的新手,我认为函数 map map和 map.map在 Haskell 中是一样的。 我的终端给了我两种不同的类型, (map.map) :: (a -> b) -> [[a]
我的目标是创建一个 map 的 map ,这样我就可以通过它的键检索外部 map 的信息,然后通过它们的键访问它的“内部” map 。 但是,当我得到每个内部映射时,我最初创建的映射变成了一个对象,我
如何使用 Java8 编写以下代码? for (Entry> entry : data.entrySet()) { Map value = entry.getValue(); if (valu
我有覆盖整个南非的图片。它们为Tiff格式,并已将坐标嵌入其中。我正在尝试拍摄这些图像(大约20张图像),并将它们用作我的iPhone应用程序中的地图叠加层。我的问题在于(准确地)将地图切成图块。 我
所以我有 2 std::map s >一个是“旧的”,一个是“新的”,我想知道哪些文件被删除了,这样就能够遍历差异并对 shared_ptr 做一些事情。这样的事情可能吗?如何做到? 最佳答案 虽然
是否可以将当前查看的 google.maps.Map 转换为静态图像链接,以便我可以获取图像并将其嵌入到 PDF 中? 我在 map 上添加了一些带有自定义图标的标记,所以我不确定这是否真的可行。 如
你能帮我吗 Java Streams ? 从标题可以看出我需要合并List>>进入Map> . 列表表示为List>>看起来像: [ { "USER_1":{
对于 idAndTags 的第二个条目,内部映射被打乱,但第一个条目则不然 第一次接近! for (Map.Entry> entryOne : idAndTags.entrySet()) {
我将从我的代码开始,因为它应该更容易理解我想要做什么: @function get-color($color, $lightness) { @return map-get(map-get($col
我过去曾在许多网站上使用过 Google map ,但遇到了以前从未遇到过的问题。 map 窗口正在显示,但它只显示左上角的 map 片段,以及之后的任何内容(即使我在周围导航时),右侧也不会加载任何
众所周知,这些 map ,无论是常规街道 map 还是卫星 map ,在中国的特定地区都无法正确排列。那么哪个 map 排列正确,是卫星 map 还是默认街道 map ?一些网站表明卫星 map 是正
在拖尾事件之后,我面临着获取此处 map 中的 map 边界的问题。我需要新的经纬度来在新更改的视口(viewport)中获取一些项目/点。我只是想在拖动结束时获得谷歌地图map.getBounds(
我想做的是通过 ajax API 显示以英国邮政编码为中心的小型 bing 生成 map 。我相信这是可能的;我在 Bing map 文档中找不到如何将英国邮政编码转换为可以插入 map Ajax 控
我有一个 List我想转换成的 e Map>其中外部字符串应为“Name”,内部字符串应为“Domain”。 Name Id Domain e(0) - Emp1, 1, Insuran
我的第 2 部分:https://stackoverflow.com/questions/21780627/c-map-of-maps-typedef-doubts-queries 然后我继续创建 I
是否可以在 1 行中使用 Java8 编写以下所有 null 和空字符串检查? Map> data = new HashMap<>(holdings.rowMap()); Set>> entrySet
我正在审查一个项目的旧代码,并使用 Map 的 Map 的 Map 获得了如下数据结构(3 层 map ): // data structure Map>>> tagTree
这可能是一种不好的做法,但我还没有找到更好的解决方案来解决我的问题。所以我有这张 map // Map>> private Map>> properties; 我想初始化它,这样我就不会得到 Null
我们在 JDK 1.7 中使用 HashMap,我在使用 SonarQube 进行代码审查时遇到了一些问题。 请考虑以下示例: public class SerializationTest imple
我是一名优秀的程序员,十分优秀!