Fgaoxing 在 Go反射:性能瓶颈与零拷贝优化 中发帖
原文:https://www.yt-blog.top/38912/
做Go开发的,肯定少不了用反射——解析Tag、拿字段偏移、获取类型信息,ORM、序列化、配置绑定这些地方都要用到。
但是官方的reflect包性能真的不太行,解析一个字段或Tag要花几十到几百万纳秒,调得多了,直接成性能瓶颈。
很多人只知道「反射慢」,但不知道慢在哪。咱们今天就从runtime层面分析一下,顺便搞个零拷贝的优化方案。
一、先从底层说起
要搞清楚反射的性能问题,得先知道Go底层是怎么回事。
从Go1.14开始,runtime里几个核心类型的内存布局就没变过。这是个关键点。
Go的反射包就是基于runtime层的abi实现的。
reflect/type.go
// TypeOf returns the reflection [Type] that represents the dynamic...