-
panic仅影响当前goroutine,触发后按LIFO执行其defer;recover只在同goroutine的defer中有效,可捕获显式panic及多数运行时panic,但无法拦截Goexit、栈溢出等致命错误。
-
Go中没有指针数组语法糖,[]*T是切片而非数组;固定长度需用[N]*T,且元素初始化为nil,解引用前须分配内存,传参时修改指针指向内容生效但修改切片头无效。
-
直接用golang.org/x/time/rate,它基于线程安全的令牌桶,支持突发流量且经生产验证;不支持分布式限流,跨实例需结合Redis或专用服务。
-
事务提交失败时,tx.Commit()才返回错误;SQL执行出错不会自动回滚,必须显式调用tx.Rollback(),且需检查每步error、避免defer误用、注意Rollback自身可能失败,超时控制与Savepoint需手动管理。
-
Go反射构建动态Mock对象核心是用reflect包运行时获取字段方法并代理调用,推荐手动构造实现接口的Mock结构体,动态代理需谨慎使用reflect.MakeFunc泛化生成。
-
Go项目稳定性依赖go.mod+go.sum+goget精准控制,禁用手动改go.mod;推荐goget@tag拉取确定版本,go.sum仅校验不锁间接依赖,CI须校验其变更,GOPROXY需禁fallback,GOSUMDB不可关闭。
-
使用sync.Pool和对象复用可显著降低Go高频分配场景下的GC压力,适用于短期、可重置的小对象;需避免大对象、长生命周期对象及goroutine泄漏风险,结合逃逸分析优先让对象留在栈上,合理设计Reset逻辑与使用边界,能减少30%~70%GC开销。
-
Go模块管理不负责依赖注入,DI需额外工具如Wire实现;Wire在编译期生成无反射的初始化代码,避免运行时错误与IDE功能退化,但Provider签名变更会导致构建失败且不受go.mod版本约束保护。
-
Implements方法用于判断类型是否实现指定接口。要正确使用Implements进行接口类型断言,需注意:1.确保比较的是接口类型,通过.Elem()提取接口类型信息;2.区分指针接收者与值接收者,值类型仅包含值接收者方法,而指针类型包含两者;3.避免混淆reflect.TypeOf与reflect.ValueOf,Implements是Type的方法;4.注意空接口影响结果;5.方法名、参数或返回值不匹配会导致误判;6.反射性能开销较大,建议用于初始化或非性能敏感场景。
-
当主goroutine进入空忙循环(如for{})时,Go调度器无法抢占执行权,导致其他goroutine永远得不到运行机会;解决方法是避免无限忙循环,改用阻塞式等待(如time.Sleep或select{})。
-
Go反射调用方法必须通过reflect.Value获取导出方法并检查IsValid()和CanCall(),值接收器可用值或指针,指针接收器必须用指针;参数需为[]reflect.Value,类型数量须严格匹配。
-
Mux是Go中功能完备的第三方路由器,支持路径变量、正则约束、子路由和中间件;需用mux.Vars提取变量,Handler推荐结构体实现,中间件可链式应用,子路由利于模块化与权限隔离。
-
text/template渲染时变量未替换,因需显式传入导出结构体、map[string]interface{}或单值;HTML内容需用template.HTML类型避免转义。
-
无缓冲channel实现同步通信,发送与接收需同时就绪;2.带缓冲channel可异步传递数据,允许预先存入指定数量值;3.channel关闭后可通过逗号-ok模式判断是否读取完毕,结合for-range遍历更安全。
-
Go项目CI/CD无需额外安装Go运行时,主流平台默认已预装;关键在环境隔离、依赖缓存(用actions/cache缓存$HOME/go/pkg/mod,key含go.sum哈希)、竞态检测(CI必须启用-race)、交叉编译配置(CGO_ENABLED=0适配静态链接,cgo需对应C工具链)及覆盖率上传(正确生成、合并、转换coverage.out)。