web-dev-qa-db-ja.com

関数のマップを移動する

関数が定義されたGoプログラムがあります。また、各機能のキーが必要なマップもあります。どうやってやるの?

私はこれを試しましたが、これは機能しません。

 func a(param string){
 
} 
 
 m:= map [string] func {
 'a_func' :a、
} 
 
キーの場合、値:=範囲m {
 if key == 'a_func' {
 value(param) 
} 
} 
45
Conceited Code

このようなことをしようとしていますか?さまざまなタイプと数の関数パラメーターを使用するように例を修正しました。

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)
        }
    }
}
57
peterSO
m := map[string]func(string, string)

あなたが署名を知っていれば動作します(そして、すべてのfuncsは同じ署名を持っています)私はこれがインターフェイスを使用するよりもクリーン/安全だと思います{}

39
Seth Hoenig

関数が同じインターフェースである場合、タイプを定義できます。

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")
}
12
smagch

@ 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の答えをご覧ください)。

7
tleb