当前位置: 首页 > news >正文

golang - 使用有缓冲通道控制并发数

在 Go 语言中,使用带缓冲的通道(buffered channels)可以有效地控制并发数。带缓冲的通道可以让你限制同时运行的 goroutine 数量,从而避免过度并发导致的资源耗尽问题。以下是一个使用带缓冲通道控制并发数的示例:

package mainimport ("fmt""sync""time"
)func worker(id int, sem chan struct{}, wg *sync.WaitGroup) {defer wg.Done()// 请求一个资源sem <- struct{}{}// 模拟耗时操作fmt.Printf("Worker %d started\n", id)time.Sleep(2 * time.Second)fmt.Printf("Worker %d finished\n", id)// 释放一个资源<-sem
}func main() {// 定义最大并发数const maxConcurrency = 3// 创建带缓冲的通道,用于限制并发数sem := make(chan struct{}, maxConcurrency)// 使用 sync.WaitGroup 等待所有 goroutine 完成var wg sync.WaitGroup// 启动 10 个 workerfor i := 1; i <= 10; i++ {wg.Add(1)go worker(i, sem, &wg)}// 等待所有 worker 完成wg.Wait()
}

在这个示例中,我们创建了一个带缓冲的通道 sem,并将其缓冲大小设置为最大并发数。我们使用了一个 sync.WaitGroup 实例来等待所有 goroutine 完成。当 worker 开始执行时,它会向通道发送一个空结构体,从而请求一个资源。如果通道已满,worker 将会阻塞,直到有可用资源。

当 worker 完成任务后,它会从通道接收一个空结构体,从而释放一个资源。这样,我们就可以通过调整 maxConcurrency 的值来控制并发数。

http://www.lryc.cn/news/163081.html

相关文章:

  • AUTOSAR测试指标
  • Vue 前端项目使用alibaba矢量库svg图标
  • 蓝桥杯官网填空题(距离和)
  • 【座位调整】Python 实现-附ChatGPT解析
  • 前端面试基础面试题——5
  • Java高并发系列: 使用wait - notify实现高效异步方法
  • 业务安全详解
  • 算法笔记--最大连续1的个数Ⅲ
  • Linux CentOS7 添加中文输入法
  • Python接口自动化封装导出excel方法和读写excel数据
  • React三属性之:refs
  • 将Vue项目迁移到微信小程序中
  • php权限调整强制用户退出的解决方案
  • [uniapp]踩坑日记 unexpected character > 1或‘=’>1 报错
  • 面试求职-经典面试问题
  • 在Linux服务器上部署Tornado项目
  • JWT认证、drf-jwt安装和简单使用、实战之使用Django auth的User表自动签发、实战之自定义User表,手动签发
  • conda常用命令及问题解决-创建虚拟环境
  • 严选算法模型质量保障
  • 学习Bootstrap 5的第七天
  • VirtualBox(内有Centos 7 示例安装)
  • 在 Git 中删除不再位于远程仓库中的本地分支
  • 容器编排学习(九)服务管理与用户权限管理
  • 【C刷题】day1
  • zabbix配置钉钉告警、和故障自愈、监控java
  • 第九章 Linux实际操作——Linux磁盘分区、挂载
  • 设计模式-解释器设计模式
  • 实现 js 中所有对象的深拷贝(包装对象,Date 对象,正则对象)
  • PathVariable注解
  • 宋浩高等数学笔记(十二)无穷级数