Problem:
Das Erstellen eines Funktionsabschnitts mit unterschiedlichen Signaturen in Golang ist herausfordernd. Unter Verwendung des bereitgestellten Codeausschnitts wirkt der Ansatz etwas „hackig“. Ist es notwendig, als Workaround ein Interface{}-Slice zu verwenden?
Lösung:
Die Verwendung eines Interface{}-Slices ist in der Tat eine gültige Lösung zum Erstellen von Slices mit Funktionen mit unterschiedlichen Signaturen. Ein alternativer Ansatz besteht jedoch darin, Reflektion zu nutzen, um die Anzahl und Art der Eingabeparameter für jede Funktion dynamisch zu bestimmen.
Hier ist ein alternatives Codebeispiel, das die Verwendung von Reflektion demonstriert:
package main import ( "fmt" "reflect" ) func A() { fmt.Println("A") } func B(a int) { fmt.Println("B", a) } func C(a string, b float32) { fmt.Println("C", a, b) } func main() { f := []interface{}{A, B, C} for _, v := range f { fn := reflect.ValueOf(v) fmt.Printf("Function: %v\n", fn.Type()) numArgs := fn.Type().NumIn() fmt.Printf("Number of arguments: %v\n", numArgs) for i := 0; i < numArgs; i++ { argType := fn.Type().In(i) fmt.Printf("Arg %v Type: %v\n", i+1, argType) } fmt.Printf("Calling function using reflection...\n") callArgs := []reflect.Value{} for i := 0; i < numArgs; i++ { switch fn.Type().In(i).Kind() { case reflect.Int: callArgs = append(callArgs, reflect.ValueOf(i+1)) case reflect.String: callArgs = append(callArgs, reflect.ValueOf(fmt.Sprintf("Arg-%v", i+1))) case reflect.Float32: callArgs = append(callArgs, reflect.ValueOf(float32(i+1))) } } fn.Call(callArgs) } }
Dieser Ansatz Bietet direkten Zugriff auf die einzelnen Funktionsparameter (sowohl Typen als auch Werte) durch Reflektion und ermöglicht so eine dynamischere Handhabung von Funktionsabschnitten mit unterschiedlichen Signaturen.
Das obige ist der detaillierte Inhalt vonWie kann ich Funktionsbereiche mit unterschiedlichen Signaturen in Go effizient verwalten?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!