首页 > 编程 > Golang > 正文

Go语言中使用 buffered channel 实现线程安全的 pool

2020-04-01 19:24:24
字体:
来源:转载
供稿:网友
这篇文章主要介绍了Go语言中使用 buffered channel 实现线程安全的 pool,因为Go语言自带的sync.Pool并不是很好用,所以自己实现了一线程安全的 pool,需要的朋友可以参考下
 

概述

我们已经知道 Go 语言提供了 sync.Pool,但是做的不怎么好,所以有必要自己来实现一个 pool。

给我看代码:

 

复制代码代码如下:

type Pool struct {
  pool chan *Client
}

 

// 创建一个新的 pool
func NewPool(max int) *Pool {
  return &Pool{
    pool: make(chan *Client, max),
  }
}

// 从 pool 里借一个 Client
func (p *Pool) Borrow() *Client {
  var cl *Client
  select {
  case cl = <-p.pool:
  default:
    cl = newClient()
  }
  return cl
}

// 还回去
func (p *Pool) Return(cl *Client) {
  select {
  case p.pool <- cl:
  default:
    // let it go, let it go...
  }
}

 

总结

现在不要使用 sync.Pool


发表评论 共有条评论
用户名: 密码:
验证码: 匿名发表