문제:
Golang에서 다양한 서명을 사용하여 함수 조각을 만드는 것은 도전적이다. 제공된 코드 조각을 사용하면 접근 방식이 다소 "해킹"된 것처럼 보입니다. 해결 방법으로 인터페이스{} 슬라이스를 활용해야 합니까?
해결책:
인터페이스{} 슬라이스를 사용하는 것은 실제로 함수가 포함된 슬라이스를 생성하는 유효한 솔루션입니다. 다른 서명으로. 그러나 대체 접근 방식은 리플렉션을 활용하여 각 함수에 대한 입력 매개 변수의 수와 유형을 동적으로 결정하는 것입니다.
다음은 리플렉션 사용을 보여주는 대체 코드 샘플입니다.
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) } }
이 접근 방식 리플렉션을 통해 개별 함수 매개변수(유형 및 값 모두)에 직접 액세스할 수 있으므로 시그니처가 다른 함수 조각을 보다 동적으로 처리할 수 있습니다.
위 내용은 Go에서 다양한 시그니처를 사용하여 여러 기능을 효율적으로 관리하려면 어떻게 해야 합니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!