golang 实现一个高并发协程工作池

package main

import (
	"fmt"
	"sync"
	"time"
)

type gPool struct {
	taskList chan int
	stop     chan struct{}
	wg       *sync.WaitGroup
}

type groutinePool interface {
	AddTask(int)
	Clean()
}

func NewGroutinePool() groutinePool {
	var p gPool
	p.taskList = make(chan int, 1000)
	p.stop = make(chan struct{})
	p.wg = new(sync.WaitGroup)

	for i := 0; i < 10; i++ {
		p.wg.Add(1)
		go func(p *gPool, i int) {
		loop:
			for {
				select {
				case task, ok := <-p.taskList:
					if !ok {
						break loop
					}
					//to do task
					//假装是个耗时任务
					fmt.Println("do task", task)
					time.Sleep(1 * time.Second)
				}
			}
			p.wg.Done()
			fmt.Println("close worker goroutine", i)
		}(&p, i)
	}
	return &p
}

func (p *gPool) AddTask(index int) {
	p.taskList <- index
}

func (p *gPool) Clean() {
	close(p.taskList)
	p.wg.Wait()
}

/*
1.来个任务直接起一个协程处理->任务多的情况下会内存爆炸
2.来个任务放channel,另起一个协程消费->任务多的情况下一个协程处理不完,添加任务时会造成阻塞
3.同2方案channel加缓冲区->缓冲区满了之后还是会导致同样问题
4.channel加缓冲&应用协程池,可有效加快处理速度,并且添加任务基本不会阻塞。

*/

func main() {
	p := NewGroutinePool()
	for i := 0; i < 1000; i++ {
		go p.AddTask(i)
	}
	time.Sleep(10 * time.Second)
	p.Clean()
}

心血来潮写了个自己玩~~

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值