Go 语言可通过 reflect 包静态分析结构体字段类型与标签构建依赖树,用于配置校验、文档生成等场景;需识别可导出结构体类型、避免循环引用、支持 tag 控制解析行为,并输出邻接表形式的依赖关系。
Go 语言本身不支持运行时自动注入或依赖发现,但借助 reflect 包可以遍历结构体字段类型、标签(tag)、嵌套关系,从而构建出结构体之间的“依赖树”——即哪些结构体被哪些字段直接或间接引用。这不是传统 IoC 容器的依赖注入,而是静态结构分析,适用于配置校验、序列化策略生成、文档自动生成、依赖可视化等场景。
核心是用 reflect.Type 获取字段类型,并区分基础类型、指针、切片、map、结构体等。重点只关注「可导出的结构体类型」(含指针指向的结构体):
field.Type,再用 Kind() 判断类型类别reflect.Struct,该字段类型本身就是依赖项reflect.Ptr、reflect.Slice、reflect.Map,需递归取其元素类型(Elem()),直到得到结构体类型结构体 A 字段包含 B,B 又包含 A,直接递归会栈溢出。需维护已访问类型的标识:
map[reflect.Type]bool 记录已进入解析的类型reflect.Type.String() 或 reflect.Type.PkgPath() + Name() 作 key,确保跨包唯一
或路径(如 A → B → C),用于后续生成依赖图通过自定义 tag(如 json:"-"、inject:"skip")显式排除某些字段参与依赖分析:
field.Tag.Get("inject")(或其他自定义 tag 名)"skip" 或 "-",直接跳过该字段"weak" 表示弱依赖(不计入主依赖树,仅记录)最终目标是得到类似 map[string][]string 的邻接表,或支持 DOT/SVG 输出的结构:
pkg.Name),值为它直接依赖的结构体名列表analyzeStruct(reflect.TypeOf((*T)(nil)).Elem())
go-graphviz 或简单缩进打印实现树形展示基本上就这些。不需要框架,纯标准库 + 小心递归 + 明确边界,就能稳稳跑出结构体间的静态依赖关系。