-
ErrGroup是为“任一goroutine出错即取消其余任务”设计的同步原语,封装WaitGroup和Context,自动处理取消传播与错误收集;手动用WaitGroup加全局error变量会导致竞态、漏判和无法及时中断。
-
Gosync包提供底层同步原语,误用易致死锁、竞态或性能退化;应依场景选Mutex/RWMutex,慎用Once.Do,WaitGroup.Add须在goroutine启动前调用,Pool仅适用于GC可控的临时对象复用。
-
Go通过接口+方法组合实现访问者模式:Element接口定义Accept方法,各具体类型实现并调用visitor对应Visit方法;Visitor接口声明VisitBook、VisitVideo等,新增操作只需实现新访问者,无需修改原有结构。
-
Go微服务测试核心是隔离依赖、可控模拟、快速验证,常用httptest.Server模拟HTTP下游,接口抽象+mock实现gRPC调用替换,结合Wire/fx管理依赖,集成测试用testcontainers组合轻量容器。
-
应使用asdf管理Go版本,因其通过asdf-golang插件独立安装各版本、动态调整PATH、不修改GOROOT,兼容go.mod/go.work;避免gvm(已停更)及手动维护导致的GOROOT冲突、CI失败等问题。
-
中介者模式通过中间协调者解耦多个对象间的直接依赖,使用sync.Map可高效实现该模式。sync.Map作为并发安全的注册表,存储组件引用并按key转发消息,避免组件间直接通信。具体步骤为:定义Mediator结构体并使用sync.Map管理组件;实现Register方法注册组件;实现Send方法通过key查找接收方并转发消息;组件需实现Component接口以接收消息。适用场景包括多组件协作、动态注册注销及简化通信逻辑的情况,同时需要注意类型断言、手动清理无效条目以防止内存泄漏等问题。
-
gRPC客户端需实现resolver.Builder接口并注册自定义DNS解析器,通过goroutine定期轮询DNS更新地址列表,且必须设置resolver.State.ServiceConfig启用负载均衡。
-
写入数据前必须显式设置precision参数,如毫秒时间戳需设为"ms",否则会被误解析为纳秒导致数据错乱;Tag应仅用于低基数、高频过滤字段,高基数字段塞入Tag会引发series爆炸和性能暴跌。
-
Go语言工厂模式通过接口+工厂函数实现,而非类继承;工厂函数返回接口类型实例,集中管理创建逻辑,提升可维护性、可测试性与扩展性。
-
HTTP请求失败需同时检查resp和err:err非nil表示网络层错误,resp.StatusCode非2xx表示服务端错误;超时应优先用context.WithTimeout;重试须区分幂等性,仅对5xx或网络超时等错误进行指数退避。
-
能,goget不能直接使用裸commithash,必须用Go自动生成的伪版本号(如v0.0.0-yyyymmddhhmmss-abcdef012345)或replace替换;伪版本时间基于commit的UTC提交时间,且被模块代理缓存。
-
runtime包可获取Go程序运行时信息,用于性能监控与调试。通过NumGoroutine()获取当前goroutine数量;ReadMemStats()获取内存与GC数据,如Alloc、TotalAlloc、NumGC等;Caller()和Callers()获取调用栈信息,辅助错误追踪;GC()手动触发垃圾回收,SetGCPercent()调整GC阈值。示例展示了goroutine变化、内存统计输出及调用栈打印。需注意避免在生产环境频繁调用影响性能的操作。
-
recover不是万能的错误处理工具,仅在defer中有效且只能捕获当前goroutine的panic;滥用会导致状态不一致、资源泄漏或掩盖问题。
-
用Golang发邮件的关键在于掌握流程和参数配置,1.准备SMTP服务器信息和账号,如Gmail为smtp.gmail.com:587、QQ邮箱为smtp.qq.com:465或587、163邮箱为smtp.163.com:465或25,需注意使用应用专用密码并确认TLS/SSL启用情况;2.使用net/smtp包发送邮件需手动拼接邮件内容,基本流程包括构造邮件内容、连接SMTP服务器并验证、发送邮件,代码示例中邮件头与正文间必须有两个\r\n;3.注意认证失败、连接超时、邮件被拒收等问题,检查密码、网络
-
reflect.MakeSlice创建动态切片必须传入reflect.Slice类型、非负长度和容量,且容量≥长度;需用reflect.SliceOf()构造切片类型,不可直接传interface{}或具体切片实例。