我遇到了这样的情况:
首先获得地图,其大小未知。
例如:myMap map[string]string
然后,我会将地图的所有键和值作为函数的args
例如func(key1, key2, ..., value1, value2, ...)
示例func:https://godoc.org/github.com/garyburd/redigo/redis#Script.Do
如何实现这一目标?
尽可能高效。
任何帮助将不胜感激:)
答案 0 :(得分:5)
我们可以使用内置len()
函数查询地图的长度。因此,我们可以创建一个足够大的切片来保存所有键和所有值。
之后,它只能在地图上迭代一次,您可以使用键填充切片的前半部分,并使用值填充切片的后半部分。
这是有效的:没有调用内置append()
,我们只在地图上迭代一次。
让我们看一个将接收密钥和值的示例函数。这个只打印所有这些:
func pairs(keysvalues ...string) {
for _, s := range keysvalues {
fmt.Print(s, ", ")
}
}
创建keysvalues
切片的代码:
m := map[string]string{
"a": "A",
"b": "B",
"c": "C",
}
count := len(m)
all := make([]string, count*2)
i := 0
for k, v := range m {
all[i], all[count+i] = k, v
i++
}
获得all
切片后,您可以像这样调用pairs()
函数:
pairs(all...)
请注意,虽然地图上的迭代顺序不是确定性的,但它可能会从迭代变为迭代。
示例输出(在Go Playground上尝试):
a, b, c, A, B, C,
注意:强>
在您的问题中,您表示所有密钥首先出现,然后遵循所有值:
func(key1, key2, ..., value1, value2, ...)
在实践中,这种情况很少见,通常会列出键值对。这种变体的工作/处理要容易得多:
func pairs(key1, value1, key2, value2, ... keyn, valuen)
如果我们想要生成这个键值对列表,那么它看起来就像这样:
count := len(m)
all := make([]string, count*2)
i := 0
for k, v := range m {
all[i], all[i+1] = k, v
i += 2
}
答案 1 :(得分:2)
例如,
package main
import "fmt"
func fn(args ...string) { fmt.Println(args) }
func main() {
m := map[string]string{"k1": "v1", "k2": "v2"}
args := make([]string, 0, 2*len(m))
for key, value := range m {
args = append(args, key)
args = append(args, value)
}
fmt.Println(args)
fn(args...)
}
输出:
[k1 v1 k2 v2]
[k1 v1 k2 v2]