-
必须先调用r.ParseMultipartForm()(或r.ParseForm())解析multipart/form-data,否则r.MultipartForm为nil,r.FormFile()将panic或返回空值;不可直接读r.Body。
-
在Beego模板中使用{{range}}时,当前作用域会切换为迭代项(如*models.Foo),导致.user等外层变量无法直接访问;需通过$.user显式引用根作用域下的数据。
-
Go字符串转数字首选strconv包,因fmt.Sscanf易panic、类型断言不安全;strconv.Atoi仅支持十进制int且精度/进制不灵活,应按需选用ParseInt/ParseUint/ParseFloat并正确处理错误、空格、科学计数法及性能问题。
-
OpenAI官方GoSDK已废弃,应使用第三方库github.com/sashabaranov/go-openai;需升级至v1.7.0+、校验APIKey、显式设置HTTP超时与重试,并严格遵循消息结构、模型名及参数格式。
-
GOOS和GOARCH必须显式设置才能交叉编译;CGO_ENABLED=0是关键开关,否则依赖C库会导致链接失败;含import"C"的代码需配对应C工具链或替换为纯Go实现。
-
Viper初始化后读不到config.yaml是因默认只在当前工作目录查找,需显式设置路径;字段为空是因未用mapstructuretag匹配YAML键名;AutomaticEnv()不生效是因环境变量名未按DATABASE_HOST规则命名;WatchConfig()仅通知变更,不自动刷新已绑定值。
-
应使用缓冲I/O、复用连接与句柄、合理并发控制及高效序列化协议:用bufio.Reader/Writer减少系统调用;复用os.File、http.Client和TCP连接;用WaitGroup/semaphore协调并发;内部通信优先gRPC+Protobuf,高频小数据选MessagePack。
-
微服务中Go的error不应直接返回调用方,须统一映射为语义明确的状态码(HTTP)或标准gRPCcode,封装为可识别类型并保留错误链,携带traceID,禁止字符串匹配,确保可观测性与重试策略分层可控。
-
Go服务被KubernetesHPA自动扩缩容的关键是暴露Prometheus格式指标端点(如/metrics),并由metrics-server或prometheus-adapter将其转换为MetricsAPI;HPA本身不拉取指标,仅通过API查询,因此需确保指标名、标签、命名空间在prometheus-adapter规则中精确匹配。
-
嵌套结构体直接用struct类型作字段,无需关键字;字段名是否导出决定包外可见性;JSON等序列化依赖structtag,须加引号;指针支持nil判断和共享数据,值类型适合小结构且必有零值;初始化需手动逐层赋值,避免nilpanic。
-
可设置性指reflect.Value能否修改底层值,需通过reflect.ValueOf(变量地址).Elem()获取并调用CanSet()判断,仅当变量可寻址且非未导出字段时返回true,否则Set()将引发panic。
-
用colly而非手动组合http.Client+goquery,因其内置反爬、重试、并发控制、去重、Cookie管理及robots.txt遵循等能力;但不支持JS渲染,需注意v2兼容性、状态码检查、合理限速与数据缓冲。
-
errors.Is和errors.As不能直接判断自定义错误类型,因二者依赖Unwrap()实现错误链遍历,若自定义错误未实现Unwrap()(哪怕返回nil),则无法被识别;正确做法是显式实现Unwrap()方法。
-
Go中合理使用const和iota可提升代码清晰性与可维护性:const定义不可变值,推荐分组管理;iota在const块内自动递增,适用于枚举、位掩码等场景。
-
Go语言通过net包实现TCP和UDP编程,支持高性能网络服务。1.TCP通信:使用net.Listen监听端口,Accept接收连接,每个连接由goroutine处理,确保并发;客户端用net.Dial建立连接,收发数据后关闭。2.UDP通信:通过net.ListenPacket或net.DialUDP创建无连接服务,适用于低延迟场景,服务端读取数据包并回发响应。3.关键点:合理利用goroutine实现并发处理,妥善处理错误,及时释放资源,根据需求选择协议,正确使用IP:Port地址格式。Go的net