関数が定義されたGoプログラムがあります。また、各機能のキーが必要なマップもあります。どうやってやるの?
私はこれを試しましたが、これは機能しません。
func a(param string){ } m:= map [string] func { 'a_func' :a、 } キーの場合、値:=範囲m { if key == 'a_func' { value(param) } }
このようなことをしようとしていますか?さまざまなタイプと数の関数パラメーターを使用するように例を修正しました。
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)
}
}
}
m := map[string]func(string, string)
あなたが署名を知っていれば動作します(そして、すべてのfuncsは同じ署名を持っています)私はこれがインターフェイスを使用するよりもクリーン/安全だと思います{}
関数が同じインターフェースである場合、タイプを定義できます。
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")
}
@ 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"
}
見苦しいと思うなら、常に型を使うことができます(@ smagchの答えをご覧ください)。