Golang Ants 构建协程池

构建的协程池实现两个目标:

1、限制协程池里开启的协程数量

2、当任务数大于协程数时,一个协程可以同时处理多个任务

3、监控是哪个协程ID处理了具体的任务

Go 复制代码
package main

import (
	"fmt"
	"runtime"
	"strconv"
	"strings"
	"sync"

	"github.com/panjf2000/ants/v2"
)

var goRoutineID []int64 = make([]int64, 20)

func printHelloWorld(i interface{}) {

	fmt.Println("hello,world:", i)

	//@todo 记录当前的协程ID
	gid := getGID()
	goRoutineID = append(goRoutineID, gid)

}

/*
*
获取协程ID
*
*/
func getGID() int64 {
	b := make([]byte, 64)
	b = b[:runtime.Stack(b, false)]
	//	fmt.Printf("%s", string(b))
	goidStr := strings.TrimPrefix(string(b), "goroutine ")
	goidStr = goidStr[:strings.Index(goidStr, " ")]
	gid, err := strconv.ParseInt(goidStr, 10, 64)
	if err != nil {
		return -1
	}
	return gid
}

func main() {
	//关闭默认池
	defer ants.Release()

	//@定义任务总数,一个协程可以处理多个任务
	runTimes := 9

	var wg sync.WaitGroup

	//@定义协程池容量:100
	//@定义任务函数:printHelloWorld
	//@协程执行完成:wg.Done:让计数器减1操作
	p, _ := ants.NewPoolWithFunc(100, func(i interface{}) {
		printHelloWorld(i)
		wg.Done()
	})

	//@关闭协程池,释放工作队列
	defer p.Release()

	//@定义任务函数的传参,通过结构体的方式传参
	callParams := struct {
		name string
		age  int
	}{
		name: "zhangsan",
		age:  44,
	}

	//@todo 提交任务
	//Invoke参数将参数传递给任务函数
	//wg.Add:计数器+1
	for i := 0; i < runTimes; i++ {
		wg.Add(1)
		_ = p.Invoke(callParams)
	}

	//@todo 阻塞等待所有的计数器清零
	wg.Wait()

	//p.Running 获取当前协程池执行工作的协程数量,注意这个不等于协程池配置的数量,比如当runTimes小于协程池配置的数量时,这时候只需要开runTimes个协程就够了,所以这里的值是runTimes
	fmt.Printf("running goroutines: %d\n", p.Running())

	//用map去重获取我们实际使用了哪些协程ID
	goRoutineBool := make(map[int64]bool, 500)
	for _, v := range goRoutineID {
		goRoutineBool[v] = true
	}

	fmt.Println("实际开启的协程ID:", goRoutineBool)

}

官方参考资料:

https://github.com/panjf2000/ants

https://pkg.go.dev/github.com/panjf2000/ants/v2@v2.9.0#section-readme

相关推荐
Victory_orsh几秒前
AI雇佣人类,智能奴役肉体
后端
踢足球09296 分钟前
寒假打卡:2026-2-7
java·开发语言·javascript
金牌归来发现妻女流落街头10 分钟前
【Springboot基础开发】
java·spring boot·后端
薛定谔的猫喵喵30 分钟前
基于PyQt5的视频答题竞赛系统设计与实现
开发语言·qt·音视频
岱宗夫up35 分钟前
Python 数据分析入门
开发语言·python·数据分析
码界筑梦坊37 分钟前
325-基于Python的校园卡消费行为数据可视化分析系统
开发语言·python·信息可视化·django·毕业设计
多恩Stone41 分钟前
【RoPE】Flux 中的 Image Tokenization
开发语言·人工智能·python
李日灐43 分钟前
C++进阶必备:红黑树从 0 到 1: 手撕底层,带你搞懂平衡二叉树的平衡逻辑与黑高检验
开发语言·数据结构·c++·后端·面试·红黑树·自平衡二叉搜索树
Risehuxyc1 小时前
备份三个PHP程序
android·开发语言·php
lly2024061 小时前
PHP Error: 常见错误及其解决方法
开发语言