Go语言技术文章
-
多协程数据共享需保证并发安全,Go提供多种机制:使用sync.Mutex或RWMutex加锁保护共享资源,避免竞态条件;优先通过channel通信传递数据而非共享内存,提升代码清晰度与安全性;对计数器等简单变量采用sync/atomic原子操作提高性能;结合context管理协程生命周期,防止泄漏。根据场景选择合适方式:简单操作用原子类型,结构化数据用互斥锁,协作任务用channel通信,可实现高效安全的并发编程。419 收藏 -
围绕 Go defer 在循环中的常见误用,解释为什么文件、连接、锁等资源会等到函数返回才释放,并给出函数拆分、显式关闭和错误处理的实战写法。418 收藏 -
本文回答 Go 普通 map 并发读写为什么会报错,解释常见误区,并通过互斥锁、sync.Map、race 检查和封装访问给出可落地的选择方法。418 收藏 -
网关结构体字段顺序不合理会导致单实例多占30%~50%内存,因高频创建、批量分配及缓存行失效加剧GC压力与延迟;需按对齐优先级(8字节>4字节>1/2字节)重排字段,并用unsafe.Sizeof和Offsetof验证padding。417 收藏 -
Go1.21+的rate.Limiter.SetLimit()可安全修改rate,但burst不变,需同比缩放;burst变更必须原子替换整个*rate.Limiter实例。415 收藏 -
应避免单独使用time.After做超时控制,因其返回的chantime.Time不可取消;正确做法是在select中同时监听业务channel和time.After返回的通道。413 收藏 -
围绕 Go 标准库 crypto/mlkem,讲清 ML-KEM-768、密钥封装、共享密钥、混合密钥交换、测试向量、密钥材料边界和生产协议落地注意事项。413 收藏 -
本文用订单查询场景,演示 Go 中如何用 fmt.Errorf 包装错误、用 errors.Is/As 判断根因和业务错误码,并在 HTTP 层统一返回清晰响应。413 收藏 -
net.Conn不支持跨goroutine并发写,需用channel+单writergoroutine串行化:定义writeReq结构体,带缓冲channel提交写请求,由专属goroutine执行conn.Write并返回结果。410 收藏 -
从生产压测角度讲清 sync.Pool 的适用边界、Get 后 Reset、Put 后不再使用、GC 清空、对象污染和 benchmark 验证方法。410 收藏 -
fmt包是Go语言格式化I/O的核心,提供Print、Println、Printf等输出函数,支持%v、%s、%d、%f等动词控制输出格式,可设置宽度、精度、对齐,并可用Sprintf构建字符串。409 收藏 -
该用io.ReadAll当需一次性获取小数据(≤10MB)的[]byte或string,如JSON响应、配置文件;该用io.Copy当需流式转发、大文件落地或写入另一io.Writer,因其内存恒定、不OOM。405 收藏 -
分析字符串拼接和 []byte 转换成本,用 Builder、Buffer 和清晰边界减少分配。404 收藏 -
Go用net包监听TCP并回显原始字节需:启动goroutine处理每个conn,循环Read()直至io.EOF;用固定缓冲区并截取有效数据;手动处理粘包/拆包;encoding/binary解析固定长度二进制头;time.AfterFunc实现可重置超时与心跳;自定义io.Writer带时间戳记录收发流量。402 收藏 -
gomodtidy自动降级或升级依赖是因Go的最小版本选择(MVS)算法:取整个依赖图中满足所有需求的最低版本;运行时会重新计算并可能回退手动升级的版本。402 收藏