最近小编一直在忙于新基于微服务下的系统开发“gqgo_engine_v1.0.0”,目标日后此系统能实现中台等架构,系统大约一个月之后将会与大家见面(开源)。因此在小编的日以继夜的开发之下突然对Go的动态调用充满了好奇,故整理下此示例:

main.go

package main
 
import (
 "lenu/call"
 "reflect"
)
 
type FuncCollection map[string]reflect.Value
 
func main() {
 _, _ = CallFunc("Hello", "执行Hello方法")
 _, _ = CallFunc("World", "执行World方法")
}
 
func CallFunc(tableName string, args ... interface{}) (result []reflect.Value, err error) {
 var router call.Routers
 FuncMap := make(FuncCollection, 0)
 rf := reflect.ValueOf(&router)
 rft := rf.Type()
 funcNum := rf.NumMethod()
 for i := 0; i < funcNum; i ++ {
  mName := rft.Method(i).Name
  FuncMap[mName] = rf.Method(i)
 }
 parameter := make([]reflect.Value, len(args))
 for k, arg := range args {
  parameter[k] = reflect.ValueOf(arg)
 }
 result = FuncMap[tableName].Call(parameter)
 return
}

package call

router.go

package call
 
import "log"
 
func (router *Routers) Hello(args ...interface{}) bool {
 log.Println(args[0])
 return true
}

world.go

package call
 
import "log"
 
func (router *Routers) World(args ...interface{}) bool {
 log.Println(args[0])
 return true
}

go run main.go会通过反射去调用Hello,World方法

关注公众号「GqGo技术实践」,随时随地都能学习。本公众号由站长亲自运营,长期更新,专注云原生、微服务、Go、Linux、Java、Swoole等技术分享,原创文章、效率工具、实战解决方案!