go实现协程池

package main

import (

"fmt"

"sync"

"sync/atomic"

"time"

)

type WorkerPool struct {

workers int

jobs chan func()

wg sync.WaitGroup

}

func NewWorkerPool(workers int) *WorkerPool {

pool := &WorkerPool{

workers: workers,

jobs: make(chan func()),

}

pool.startWorkers()

return pool

}

func (p *WorkerPool) startWorkers() {

for i := 0; i < p.workers; i++ {

go func() {

for job := range p.jobs {

job()

}

}()

}

}

func (p *WorkerPool) Do(job func()) {

p.wg.Add(1)

go func() {

defer p.wg.Done()

p.jobs <- job

}()

}

func (p *WorkerPool) Wait() {

p.wg.Wait()

close(p.jobs)

}

func main() {

pool := NewWorkerPool(10)

var count int32

for i := 0; i < 100; i++ {

pool.Do(func() {

time.Sleep(10 * time.Millisecond)

atomic.AddInt32(&count, 1)

})

}

pool.Wait()

fmt.Printf("Count is %d\n", count)

}

相关推荐
他是龙55113 小时前
68:Java 原生反序列化 & SpringBoot 攻防
java·开发语言·spring boot
cen__y13 小时前
Linux05(管道)
linux·运维·服务器·c语言·开发语言·文件流
Frank学习路上13 小时前
【Python】应用:发布pyproject.toml格式包到 PyPI
开发语言·chrome·python
奇妙之二进制13 小时前
zmq源码分析之IO线程绑定时机
开发语言·网络
阿标的博客13 小时前
Python学习(三):Python程序的运行方式
开发语言·python·学习
玖玖passion13 小时前
React 常用 Hooks 函数及使用方法完全指南(useState / useEffect / useRef / useContext / useCallback / useMemo / useReducer)
前端·javascript
0xDevNull13 小时前
分布式事务实战指南:从理论到Seata落地
java·开发语言·后端
t***54413 小时前
如何在 Dev-C++ 中配置 Clang 编译器
开发语言·c++
码云数智-大飞13 小时前
TLS 1.3的革新:更快的速度与更强的安全性
开发语言·php
TechMasterPlus13 小时前
Hermes 深度解析:React Native 高性能 JavaScript 引擎实践指南
javascript·react native·react.js