-
WithCancel仅对监听ctx.Done()的逻辑生效,须配合支持context的API使用;WithValue只存请求级不可变元数据,键需自定义类型,避免传可变对象或依赖实例。325 收藏 -
Go中判断变量是否为零值应优先用reflect.Value.IsZero(),它安全支持所有类型并正确识别nil指针、接口等;但需避免直接传nil接口,结构体字段检查限于导出字段,且推荐类型特化比较替代反射。444 收藏 -
能,但需谨慎;命名返回值是函数内变量,defer可修改它,常用于资源清理时透传Close等错误,但须判空且避免无条件覆盖主逻辑错误。304 收藏 -
sync.Mutex不能当信号量用,因其仅支持单并发互斥,而信号量需N级许可控制;正确做法是用golang.org/x/sync/semaphore等带计数与上下文感知的许可池。321 收藏 -
conn.Read()返回0字节且err为io.EOF时必须立即关闭连接,否则会导致空转和CPU暴涨;需同时检查n==0和err==io.EOF作为终止信号,而非仅判断err!=nil。149 收藏 -
跨平台构建需正确设置GOOS和GOARCH环境变量,依赖始终按host平台解析,仅build/run时应用目标平台约束;含cgo时须设CGO_ENABLED=0;vendor不区分平台,但模块须跨平台友好;私有模块拉取依赖GOPRIVATE和凭据配置;缓存污染是隐形陷阱,应定期goclean-cache-modcache。260 收藏 -
Go标准库的encoding/xml和encoding/json不支持访问者模式,需用xml.Decoder.Token()流式解析XML或json.RawMessage延迟解析JSON,或选用gjson/xmlquery等第三方库实现类似功能。108 收藏 -
答案:Go反射通过reflect.Type和reflect.Value实现运行时类型与值的动态操作,适用于ORM、序列化、依赖注入等场景,但需注意性能开销、类型安全、可维护性及CanSet限制。258 收藏 -
Go中goroutine是轻量级并发单元,用go关键字启动;需用sync.WaitGroup等同步机制防止主goroutine提前退出导致其他协程被终止。169 收藏 -
errorwrapping确实带来20%-40%性能开销,主要源于内存分配与字符串拼接,但因仅发生在错误路径且频率低,多数场景可忽略;高频错误、底层库或资源敏感环境需谨慎设计,通过减少冗余包装、使用哨兵错误和延迟包装等策略平衡可观测性与性能。426 收藏 -
goroutine泄漏是最隐蔽危险的并发错误,因channel未关闭、锁未释放或select缺少default/case导致goroutine阻塞等待而无法回收。310 收藏 -
Go二进制默认静态链接、零外部依赖,但需警惕隐性环境依赖:cgo启用、外部命令调用、硬编码系统路径、TLS证书查找、DNS解析及嵌入资源管理。306 收藏 -
Go编译器(gc)在绝大多数情况下会将a/2、a*2、a%2等整数算术操作自动优化为等效的位运算(如a>>1、a<<1、a&1),但优化行为因有符号(int)与无符号(uint)类型而异,且语义完全等价仅限于无符号类型。213 收藏 -
结构体字段应按宽度降序排列以减少内存填充,如将int64放前、byte放后;嵌套结构体需整体前置以满足对齐;用unsafe.Offsetof和unsafe.Sizeof验证布局;优化适用于高频小对象场景。457 收藏 -
策略函数签名必须统一,推荐func(ctxcontext.Context,reqinterface{})(interface{},error);map需显式make初始化;key须注册时标准化(如ToLower/Trim);禁止策略内panic,须返回error。361 收藏