
Goroutine 池:提升 Golang 并发编程效率
简介
Goroutine 池是一种用于管理 Goroutine(Go 语言中的轻量级线程)的机制。通过维护预先分配的 Goroutine 集,它可以减少创建和销毁 Goroutine 的开销,从而提高并发编程的效率。
创建 Goroutine 池
import (
"sync"
"sync/atomic"
)
type Pool struct {
// 存储已创建的 Goroutine
goroutines chan func()
// 跟踪当前活动 Goroutine 数量
active int64
}
func NewPool(size int) *Pool {
return &Pool{
goroutines: make(chan func(), size),
active: 0,
}
}使用 Goroutine 池
立即学习“go语言免费学习笔记(深入)”;
Goroutine 池使用方法:
-
获取 Goroutine:从池中获取一个空闲的 Goroutine。
func (p *Pool) Get() func() { // 如果池中没有可用 Goroutine,则创建一个新的 if p.available() <= 0 { p.grow() } return <-p.goroutines } -
执行任务:在获取的 Goroutine 中执行任务。
func (p *Pool) Run(f func()) { g := p.Get() defer func() { p.put(g) }() g() } -
释放 Goroutine:当任务执行完毕后,将 Goroutine 归还给池中。
func (p *Pool) put(g func()) { p.goroutines <- g atomic.AddInt64(&p.active, -1) }
实战案例
让我们考虑一个需要并发处理任务的 Web 服务示例:
import "github.com/ChrisRx/goroutine-pool"
func main() {
// 创建一个 Goroutine 池
pool := goroutine_pool.NewPool(10) // 10 个 Goroutine 的池
for i := 0; i < 100; i++ {
// 将任务提交给池
pool.Run(func() {
fmt.Println("Task ", i, " executed")
})
}
// 等待所有任务完成
pool.Wait()
}优点
使用 Goroutine 池的优点包括:
- 减少创建和销毁 Goroutine 的开销
- 提高并发应用程序的效率
- 简化并发编程










