Go语言学习10-sync.Pool对象缓存

Go语言学习10-sync.Pool对象缓存

sync.Pool 对象获取

  • 尝试从私有对象获取
  • 私有对象不存在, 尝试从当前 Processor 的共享池获取
  • 如果当前 Processor 共享池也是空的, name就尝试去其他 Processor 的共享池获取
  • 如果所有子池都是空的, 最后就用用户指定的 New 函数产生一个新的对象返回

sync.Pool 对象的放回

  • 如果私有对象不存在则保存为私有对象
  • 如果私有对象存在, 放入当前 Processor 子池的共享池中

使用 sync.Pool

go 复制代码
pool := &sync.Pool{
	New: func() interface{} {
		return 0
	},
}

arry := pool.Get().(int)
	...
pool.Put(10)

sync.Pool 对象的生命周期

  • GC 会清除 sync.pool 缓存的对象
  • 对象的缓存有效期为下一次 GC 之前

sync.Pool 总结

  • 适合于通过复用, 降低复杂对象的创建 和 GC 代价
  • 协程安全, 会有锁的开销
  • 声明周期受 GC 影响, 不适合于做连接池等, 需自己管理声明周期的资源的池化
相关推荐
golang学习记1 天前
Go 实时批处理:让数据库少挨点打 [特殊字符]
开发语言·数据库·golang
hutengyi1 天前
go测试问题记录
开发语言·后端·golang
KevinCyao1 天前
Go短信营销接口示例代码:Golang高并发调用营销短信接口的实现方案与代码分享
android·前端·网络·golang·前端框架
精神小伙就是猛1 天前
使用go-zero快速搭建一个微服务(一)
开发语言·后端·微服务·golang
不会聊天真君6471 天前
基础语法·下(golang笔记第三期)
开发语言·笔记·golang
大阿明1 天前
Go基础之环境搭建
开发语言·后端·golang
人间打气筒(Ada)1 天前
go:如何保障分布式系统的高可用性?(下篇)
golang·高可用·超时设计·限流设计·接口缓存·重试设计·无状态设计
Bruce20489981 天前
Go 云原生实战:K8s Operator 开发与服务网格(Istio)落地
云原生·golang·kubernetes
不会写DN2 天前
Go 生态最快 JSON 库 - jsoniter
开发语言·golang·json
2401_895521342 天前
Golang 构建学习
开发语言·学习·golang