golang
已收录文章:127篇
-
使用sync.WaitGroup和channel可处理Go中简单任务依赖,复杂场景宜构建DAG调度器或采用第三方库,结合context实现超时控制与错误传播。262 收藏
-
高并发日志优化核心是稳且可伸缩:通过带缓冲channel异步中转,专用goroutine批量写入,复用LogEntry减少GC,选用zerolog/zap等零分配库,结合bufio.Writer聚合写入,避免频繁syscall与锁竞争,控制日志级别与采样,源头减负。262 收藏
-
闭包能捕获外部作用域变量,但在循环中所有闭包共享同一变量实例,导致意外结果,需通过副本传递避免陷阱。256 收藏
-
匿名函数是无名函数,可直接定义调用或赋值使用,常用于闭包、延迟初始化及并发控制;如通过闭包实现计数器,或在循环中配合goroutine避免变量共享问题。254 收藏
-
答案:Golang中通过令牌桶算法实现限速任务调度,可使用rate.Limiter或自定义TokenBucket控制并发。251 收藏
-
在Golang中通过接口和组合实现状态模式,定义OrderState接口并让各状态结构体实现它,上下文OrderContext持有当前状态并将操作委托给具体状态,实现行为解耦与状态转换,提升可维护性。249 收藏