golang: 使用有缓存通道对goroutine并发数控制

本文介绍如何在Golang中使用有缓存通道来有效控制goroutine的并发数,通过示例展示了当限制并发数为2,任务数为6时的工作流程。
摘要由CSDN通过智能技术生成

首先发布于我的gist

package main

import (
	"fmt"
	"html"
	"io/ioutil"
	"log"
	"net/http"
	"sync"
	"time"
)

func GetConcurrently() {
   
	// set limit to 10, and make a buffered channel
	limit := 10
	limiterChan := make(chan struct{
   }, limit)
	for i := 0; i < limit; i++ {
   
		limiterChan <- struct{
   }{
   }
	}

	// set num of goroutines to 1 << 6
	// num = 1 * 2^6 = 64
	num := 1 << 6

	// use sync.Waitgro
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值