最近小编一直在忙于新基于微服务下的系统开发“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等技术分享,原创文章、效率工具、实战解决方案!