golang
已收录文章:14106篇
-
Golang的并发模型适合高并发微服务场景,主要通过以下三点实现:1.使用Goroutine实现非阻塞请求处理,将独立任务并发执行以减少响应时间;2.利用Channel进行安全的数据通信与同步,确保多任务完成后统一汇总结果;3.使用WorkerPool控制并发资源,通过固定数量的工作goroutine处理任务,防止资源耗尽,从而提升系统吞吐能力。215 收藏
-
先通过reflect.TypeOf获取结构体类型,再遍历字段并调用Tag.Get方法提取标签值,实现对JSON、DB等标签的动态解析与处理。215 收藏
-
Go通过encoding/json包实现JSON处理,使用struct标签映射字段,json.Marshal/Unmarshal进行序列化与反序列化,支持omitempty、-等标签控制输出行为,结构体字段需大写开头,可结合map[string]interface{}处理动态JSON。215 收藏
-
接口定义行为规范,指针实现可避免复制、提升性能并修改状态。Dog和Car用指针实现Mover接口,避免值拷贝;大型结构体或需修改状态时应使用指针接收者;接口零值为nil,调用前需判空;接口可组合,如ReadWriter嵌入Reader和Writer,提升复用性。215 收藏
-
并发安全的关键是保护指针指向的数据而非指针本身,多goroutine下需防止数据竞争。使用atomic可对简单类型实现高效无锁操作,如原子读写、增减和比较交换,适用于计数器等单一变量场景;涉及复杂结构或多个操作原子性时应选用mutex或RWMutex,确保临界区互斥,读多写少用RWMutex提升性能。基本原则:优先atomic保证性能,复杂逻辑用锁确保正确性,结合-race工具检测问题。215 收藏
-
开篇 在 Golang 的标准库 container 中,包含了几种常见的数据结构的实现,其实是非常好的学习材料,我们可以从中回顾一下经典的数据结构,看看 Golang 的官方团队是如何思考的。 container/list 双214 收藏