関数が定義された Go プログラムがあります。また、各機能のキーを持つ必要があるマップもあります。どうやってやるの?
これを試しましたが、うまくいきません。
func a(パラメータ文字列) { } m := マップ[文字列] func { 'a_func': a, } for key, value := range m { キーの場合 == 'a_func' { 値(パラメータ) } }
このようなことをしようとしていますか?さまざまな型と数の関数パラメーターを使用するように例を修正しました。
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)
署名がわかっている場合 (およびすべての関数が同じ署名を持っている場合) に動作します。これは、インターフェイスを使用するよりもクリーンで安全だと思います{}
関数が同じインターフェイスの場合、型を定義できます。
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の回答を参照)。