V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
atVoid
V2EX  ›  程序员

Go 简单易用的反射工具库, 支持设置嵌套结构体字段, 函数调用, etc.

  •  
  •   atVoid ·
    morrisxyang · 2023-09-01 14:14:11 +08:00 · 694 次点击
    这是一个创建于 445 天前的主题,其中的信息可能已经有所发展或是发生改变。

    介绍

    在实际业务开发中, 经常需要用到反射的能力, 比如结合远程配置动态修改结构体的字段, 这样无需发布即可实现功能变更, 再比如拓展插件的场景, 使用表驱动的方式调用一些异构的函数(无法抽象为接口)等. 这里对常用的操作进行了 getter, setter 的封装, 并增强了一些能力, 比如支持设置多层嵌套结构体的字段, 针对结构体指针自动创建等.

    地址: https://github.com/morrisxyang/xreflect
    中文文档: https://github.com/morrisxyang/xreflect/blob/main/README_CN.md

    如果觉得有用欢迎 Star 和 PR, 有问题直接提 Issue

    xreflect

    一个简单的, 易用的反射工具库.

    主要支持如下特性:

    • 设置结构体字段值, 支持通过路径比如A.B.C设置嵌套结构体字段的值

    • 获取结构体字段的值, 类型, Tag 等.

    • 遍历结构体所有字段, 支持 select 模式和 range 模式, 如果使用深度遍历方法比如 FieldsDeep 将遍历所有嵌套结构.

    • 函数调用, 方法调用, 支持可变参数.

    • 新建实例, 判断接口实现等等.

    安装和文档

    安装命令 go get github.com/morrisxyang/xreflect.

    文档见 https://pkg.go.dev/github.com/morrisxyang/xreflect

    快速开始

    设置嵌套结构体字段值

    person := &Person{
    	Name: "John",
    	Age:  20,
    	Country: Country{
    		ID:   0,
    		Name: "Perk",
    	},
    }
    
    _ = SetEmbedField(person, "Country.ID", 1)
    
    // Perk's ID: 1 
    fmt.Printf("Perk's ID: %d \n", person.Country.ID)
    

    调用函数

    var addFunc = func(nums ...int) int {
    		var sum int
    		for _, num := range nums {
    			sum += num
    		}
    		return sum
    }
    
    res, _ := CallFunc(addFunc1, 1, 2, 3)
    
    // 6
    fmt.Println(res[0].Interface())
    

    核心方法

    FieldX

    SetX

    StrcutFieldX

    FuncX

    Others

    FAQ

    FieldStrcutField 的区别是?

    Field 返回 reflect.Value, StrcutField 返回 reflect.StrcutField.

    atVoid
        1
    atVoid  
    OP
       2023-09-01 14:16:01 +08:00
    欢迎指正
    关于   ·   帮助文档   ·   博客   ·   API   ·   FAQ   ·   实用小工具   ·   5321 人在线   最高记录 6679   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 26ms · UTC 03:46 · PVG 11:46 · LAX 19:46 · JFK 22:46
    Developed with CodeLauncher
    ♥ Do have faith in what you're doing.