收集整理的这篇文章主要介绍了Golang动态调用方法小结,觉得挺不错的,现在分享给大家,也给大家做个参考。
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 type Routers struct { }
hello.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方法
到此这篇关于Golang动态调用方法小结的文章就介绍到这了,更多相关Golang动态调用内容请搜索以前的文章或继续浏览下面的相关文章希望大家以后多多支持!
您可能感兴趣的文章:
- Golang中Map按照Value大小排序的方法实例
- Go interface{ } 转切片类型的实现方法
- go实现一个分布式限流器的方法步骤
- Go 实现 Nginx 加权轮询算法的方法步骤
- go语言类型方法集为类型添加方法示例解析