阅读(3083) (10)

GoFrame gpool-基本介绍

2022-04-07 11:22:39 更新

基本介绍

对象复用池(并发安全)。将对象进行缓存复用,支持过期时间、创建方法及销毁方法定义。

使用场景:任何需要支持定时过期的对象复用场景。

使用方式:

import "github.com/gogf/gf/v2/container/gpool"

接口文档:

https://pkg.go.dev/github.com/gogf/gf/v2/container/gpool

需要注意:

  1. New​方法的过期时间类型为​time.Duration​。
  2. 对象创建方法(​newFunc NewFunc​)返回值包含一个​error​返回,当对象创建失败时可由该返回值反馈原因。
  3. 对象销毁方法(​expireFunc...ExpireFunc​)为可选参数,用以当对象超时/池关闭时,自动调用自定义的方法销毁对象。

gpool与sync.Pool

gpool​与​sync.Pool​都可以达到对象复用的作用,但是两者的设计初衷和使用场景不太一样。

sync.Pool​的对象生命周期不支持自定义过期时间,究其原因,​sync.Pool​并不是一个​Cache​;​sync.Pool​设计初衷是为了缓解​GC​压力,​sync.Pool​中的对象会在​GC​开始前全部清除;并且​sync.Pool​不支持对象创建方法及销毁方法。