golang
已收录文章:13959篇
-
策略模式通过接口封装不同算法,使算法可互换且与客户端解耦;Go语言利用接口和组合实现该模式,如定义SortStrategy接口及冒泡、快速排序等实现,通过Sorter上下文动态切换算法,实现解耦与扩展。437 收藏
-
用Golang构建DevOps工具链可实现从代码提交到部署运维的全自动化闭环。1.利用gobuild和交叉编译特性,结合Git事件触发自动化构建,生成带版本标签的静态二进制并上传制品库;2.使用Go编写部署控制器,通过SSH、KubernetesAPI或云SDK实现滚动更新、蓝绿发布,并集成Consul做服务发现,部署前自动执行数据库迁移;3.开发高性能日志采集Agent,结构化日志输出至ELK/Loki,暴露Prometheus指标,集成OpenTelemetry实现链路追踪,异常时通过钉钉或企业微信告474 收藏
-
Golang处理时间的关键在于掌握time.Now()获取当前时间、格式化与解析的方法以及时间计算和比较。1.使用time.Now()获取当前时间对象或时间戳;2.格式化时间需基于参考时间“2006-01-0215:04”进行定义;3.解析字符串为时间需严格匹配格式并注意时区;4.时间加减通过Add方法结合time.Duration实现;5.比较时间使用After、Before或Equal方法,计算间隔可用Sub方法获取时间差。116 收藏
-
Go语言中通过channel和goroutine实现发布订阅模式,核心角色为发布者、订阅者和消息中心。使用chan传递消息,消息中心管理订阅关系并广播消息,支持多主题、动态增删订阅者,利用缓冲channel避免阻塞,确保高效并发。示例中定义Topic、Event、Subscriber及PubSub结构,通过Start启动事件循环,Subscribe注册订阅,Publish发送消息,Unsubscribe移除订阅者,Stop停止服务。每个订阅者独立接收消息,发布者将事件推送到对应主题的channel,所有订165 收藏
-
减少Golang锁竞争的核心是避免不必要的锁操作。1.使用atomic包进行原子操作,如atomic.AddInt64,适用于计数器等简单场景,避免Mutex的系统调用开销;2.利用sync.Pool复用对象,减少内存分配与GC压力,间接降低锁竞争;3.缩小锁粒度,仅保护必要临界区;4.读多写少场景使用sync.RWMutex,允许多个读并发执行;5.通过channel替代共享内存通信,避免锁的使用。不同场景应选择合适机制:atomic适合简单操作,RWMutex适合读多写少,channel适合gorou157 收藏
-
使用proto3定义gRPC服务,通过message和service定义数据与接口,生成Go代码实现高效通信。435 收藏