-
io.Copy仅流式搬运字节,不处理目录创建、元数据保留、原子性及内存控制;需手动mkdir、open/create文件、close资源,并用bufio优化大文件复制。
-
在Go中,将新分配结构体的指针同时存入切片并返回给调用方,不会导致内存泄漏——因为Go的垃圾回收器(GC)会自动追踪所有可达引用,只要对象不再被任何活跃变量或数据结构引用,就会被安全回收。
-
Golang云原生应用优化核心是提升稳定性、启动速度与资源效率。需精简二进制(-ldflags="-s-w")、控制goroutine泄漏、复用内存(sync.Pool)、适配cgroup限制、设置合理超时及轻量健康检查。
-
抽象工厂模式在Go中通过接口定义产品能力、结构体实现具体产品、工厂函数或结构体返回接口实例来实现,客户端仅依赖接口;支持主题扩展与函数选项定制。
-
扇出模式下避免goroutine泄漏的关键是让每个goroutine对上下文生命周期敏感:所有通道操作必须用select包裹send/recv和ctx.Done();输入通道需明确关闭边界;避免无缓冲通道用于中间层,缓冲大小须匹配并发数。
-
双指针是用两个索引变量协同遍历的思路,非Go语法特性;快慢指针适用于有序去重、链表环检测等依赖速度差的场景,对撞指针适用于两数之和、回文判断等依赖两端收缩的场景。
-
RedisSETNX不适合直接当分布式锁用,因其缺乏过期机制易致死锁、无身份校验会误删、超时释放引发数据不一致;需结合唯一value、Lua原子校验删除、自动续期等机制才安全。
-
context.WithDeadline用于设置绝对截止时间,当系统时钟达到该时间点时自动取消任务;它与WithTimeout的区别在于前者基于time.Time(绝对时间),后者基于time.Duration(相对时间);选择前者适用于固定截止时刻的场景,如协议要求在某时间前完成;使用时需注意父Context取消会传递给子Context,且子Context实际生效的截止时间遵循“最早截止时间”原则;常见陷阱包括时区不一致、遗漏cancel调用导致资源泄漏、过度嵌套Deadline及与重试机制冲突;最佳实
-
反射赋值前必须确保Value可寻址且可设置,正确做法是传入指针并调用Elem();结构体字段需导出且实例可寻址;SetString仅接受string类型;SetFloat对float32会静默截断精度;嵌套指针字段需判空再创建实例;务必用CanSet()校验并处理nil指针。
-
Benchmark函数名须以Benchmark开头、参数为*testing.B;需预热构造数据、避免循环内重复分配;用-bench=.-benchmem关注ns/op和B/op,多函数对比时每次只改一个变量。
-
全链路加密需覆盖服务通信、配置加载、日志脱敏、数据落盘四环节;禁用InsecureSkipVerify,启用双向TLS;bbolt落盘须AEAD加密+KMS密钥;Envoy管传输层,Go管业务层加密;日志须结构化脱敏。
-
gomock报错“interfacehasunexportedmethods”是因为只支持mock首字母大写的导出方法;第三方非导出接口应通过包装暴露可导出接口;mockgen推荐用-source源码模式,Go1.18+需v1.6.0+;测试中须先EXPECT()再调用,结尾调Finish()校验。
-
Go标准库sql.Tx不支持嵌套事务,所谓嵌套仅为逻辑分组;真正局部回滚需依赖数据库SavePoint(如PostgreSQL/MySQL8.0+),通过tx.Exec执行SAVEPOINT/ROLLBACKTOSAVEPOINT手动管理,但需注意生命周期、命名冲突和驱动兼容性问题。
-
应使用json.RawMessage跳过不必要的解析,仅在需要时解构;结合sync.Pool复用结构体减少GC;优先用json.Decoder处理流式或大JSON;替换标准库为easyjson或go-json以规避反射开销。
-
typeT1T2创建全新类型,不可与底层类型互换且可定义方法;typeT1=T2仅为别名,完全等价但不可附加方法。