-
Go中代理模式用组合+接口契约实现:定义公共接口,真实对象和代理对象均实现它,代理内部持有接口类型字段;避免嵌入结构体或存储具体类型指针,除非需访问非接口方法。399 收藏 -
编写以Benchmark开头的函数并接收*testing.B参数,2.使用b.N循环执行目标代码,3.通过gotest-bench运行测试,4.分析每次迭代耗时以评估性能。423 收藏 -
答案:优化Go中map与struct混合操作需减少类型断言与反射、合理选择嵌套方式、使用指针避免拷贝、预分配map容量,并根据并发场景选用sync.Map或分片锁,提升内存局部性与性能。379 收藏 -
最直接识别Go文件权限错误的方法是用os.IsPermission判断error——它专为“权限拒绝”设计,比字符串匹配更准确稳定,适用于os.Open、os.WriteFile、os.Mkdir等操作。388 收藏 -
Go中错误包装核心是用fmt.Errorf配合%w动词或errors.Join、Unwrap等,实现可追溯、信息丰富的错误链;%w嵌入原始错误,保留类型判定能力;需逐层添加上下文;自定义错误类型可实现Unwrap接口;日志中应展开错误链便于调试。465 收藏 -
bufio通过内存缓冲区减少系统调用,批量读写提升吞吐量;推荐缓冲区4KB–64KB;日志追加写用NewWriterSize+定期Flush可提速3–10倍。208 收藏 -
recover必须在defer函数内调用才有效,否则返回nil;它仅在goroutine处于panic状态且位于defer函数体内时捕获panic,捕获后原函数不继续执行,仅恢复上层控制流。154 收藏 -
必须用带缓冲的chanerror回传可预期错误,并在每个goroutine内用defer+recover捕获panic转为error发送;chan容量至少为1,避免阻塞导致泄漏。340 收藏 -
os.Read比bufio.Reader.Read慢因每次调用均触发系统调用,而后者用4KB缓冲区减少syscall频次;建议顺序读取时统一用bufio.NewReader,小粒度读取收益更明显。163 收藏 -
基准测试需明确目标(延迟/QPS/内存/GC)、匹配业务的数据规模,用-benchmem监控分配,预生成可控数据,拆解关键路径逐层压测,单变量调优,并用pprof定位CPU和内存瓶颈。213 收藏 -
Go1.13起默认启用GOPROXY,依赖下载加速依赖代理(如goproxy.cn)与本地模块缓存($GOPATH/pkg/mod),首次下载后复用本地缓存,配合CI/CD持久化或私有Proxy实现高效复用。272 收藏 -
gotest-bench不是压力测试,它仅测handler内存执行开销,需禁用sleep、加b.ResetTimer、用-benchmem查分配;vegeta是轻量HTTP压测首选,支持P95/P99和直方图;手写脚本需控并发、复用client、禁keep-alive;压测必采pprof,关注调度器、锁、GC瓶颈。470 收藏 -
延迟初始化指将资源初始化推迟到首次使用时,Go中可通过sync.Once或Go1.21的sync.Lazy实现,适用于数据库连接、配置加载等非核心组件,能显著降低启动耗时,提升微服务和Serverless场景下的冷启动性能。341 收藏 -
控制并发数量,避免资源耗尽,使用带缓冲channel作为信号量限制并发,如sem:=make(chanstruct{},10)实现最多10个并发执行。143 收藏 -
不能直接用goroutine调log.Printf写文件,因*log.Logger非并发安全,多goroutine并发写同一文件会引发竞态,导致日志错乱、截断或丢失。227 收藏