Versions Compared

Key

  • This line was added.
  • This line was removed.
  • Formatting was changed.

...

基本介绍

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

使用场景

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

使用方式

Code Block
languagego
import "github.com/gogf/gf/v2/container/gpool"

...

接口文档

https://

...

...

...

  1. New方法的过期时间类型为time.Duration

...

  1. 对象创建方法(newFunc NewFunc)返回值包含一个error

...

  1. 返回,当对象创建失败时可由该返回值反馈原因。
  2. 对象销毁方法(expireFunc...ExpireFunc)为可选参数,用以当对象超时/

...

  1. 池关闭时,自动调用自定义的方法销毁对象。

...

gpoolsync.Pool

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

sync.Pool的对象生命周期不支持自定义过期时间,究其原因,sync.Pool

...

并不是一个Cachesync.Pool

...

设计初衷是为了缓解GC压力sync.Pool

...

中的对象会在GC开始前全部清除;并且sync.Pool不支持对象创建方法及销毁方法。

相关文档

Children Display

使用示例1,基本使用

package main

import (
    "github.com/gogf/gf/container/gpool"
    "fmt"
    "time"
)

func main () {
    // 创建一个对象池,过期时间为1秒
    p := gpool.New(time.Second, nil)

    // 从池中取一个对象,返回nil及错误信息
    fmt.Println(p.Get())

    // 丢一个对象到池中
    p.Put(1)

    // 重新从池中取一个对象,返回1
    fmt.Println(p.Get())

    // 等待2秒后重试,发现对象已过期,返回nil及错误信息
    time.Sleep(2*time.Second)
    fmt.Println(p.Get())
}

使用示例2,创建及销毁方法

我们可以给定动态创建及销毁方法。

package main

import (
	"fmt"
	"github.com/gogf/gf/container/gpool"
	"github.com/gogf/gf/net/gtcp"
	"github.com/gogf/gf/os/glog"
	"time"
)

func main() {
	// 创建对象复用池,对象过期时间为3秒,并给定创建及销毁方法
	p := gpool.New(3*time.Second, func() (interface{}, error) {
		return gtcp.NewConn("www.baidu.com:80")
	}, func(i interface{}) {
		glog.Println("expired")
		i.(*gtcp.Conn).Close()
	})
	conn, err := p.Get()
	if err != nil {
		panic(err)
	}
	result, err := conn.(*gtcp.Conn).SendRecv([]byte("HEAD / HTTP/1.1\n\n"), -1)
	if err != nil {
		panic(err)
	}
	fmt.Println(string(result))
	// 丢回池中以便重复使用
	p.Put(conn)
	// 等待一定时间观察过期方法调用
	time.Sleep(4*time.Second)
}

执行后,终端输出结果:

...

alltrue
excerptTypesimple






Panel
titleContent Menu

Table of Contents