pet*_*rSO 58
你想做这样的事吗?我修改了示例以使用不同类型和数量的函数参数.
package main
import "fmt"
func f(p string) {
fmt.Println("function f parameter:", p)
}
func g(p string, q int) {
fmt.Println("function g parameters:", p, q)
}
func main() {
m := map[string]interface{}{
"f": f,
"g": g,
}
for k, v := range m {
switch k {
case "f":
v.(func(string))("astring")
case "g":
v.(func(string, int))("astring", 42)
}
}
}
Run Code Online (Sandbox Code Playgroud)
Set*_*nig 42
m := map[string]func(string, string)
Run Code Online (Sandbox Code Playgroud)
如果您知道签名(并且所有func具有相同的签名),则可以工作.我认为这比使用接口{}更干净/更安全
小智 13
如果函数是相同的接口,则可以定义类型.
package main
import "log"
type fn func (string)
func foo(msg string) {
log.Printf("foo! Message is %s", msg)
}
func bar(msg string) {
log.Printf("bar! Message is %s", msg)
}
func main() {
m := map[string] fn {
"f": foo,
"b": bar,
}
log.Printf("map is %v", m)
m["f"]("Hello")
m["b"]("World")
}
Run Code Online (Sandbox Code Playgroud)
@Seth Hoenig的回答对我帮助最大,但我只是想补充说Go接受具有定义返回值的函数:
package main
func main() {
m := map[string]func(string) string{
"foo": func(s string) string { return s + "nurf" },
}
m["foo"]("baz") // "baznurf"
}
Run Code Online (Sandbox Code Playgroud)
如果你觉得它很难看,你可以随时使用一种类型(参见@smagch的回答).