[Go] 利用有缓存channel控制同时并发的数量
如果有一个大循环,里面每一个都开启groutine,那么瞬间就会开启非常多的groutine,要解决这个问题就要用channel的阻塞特性来解决
package main import "time" import "fmt" func main() { control := make(chan interface{}, 2) for i := 1; i <= 10; i++ { control <- i //这里应该放上面,如果放下面就会每次都执行三个了 go func(j int) { fmt.Printf("go func: %d, time: %d\n", j, time.Now().Unix()) time.Sleep(time.Second) <-control }(i) } //主groutine不要断 for { time.Sleep(time.Second) } }
go func: 2, time: 1574427632 go func: 1, time: 1574427632 go func: 4, time: 1574427633 go func: 3, time: 1574427633 go func: 5, time: 1574427634 go func: 6, time: 1574427634 go func: 7, time: 1574427635 go func: 8, time: 1574427635 go func: 9, time: 1574427636 go func: 10, time: 1574427636
看时间每次只是同时执行两个
十年开发经验程序员,离职全心创业中,历时三年开发出的产品《唯一客服系统》
一款基于Golang+Vue开发的在线客服系统,软件著作权编号:2021SR1462600。一套可私有化部署的网站在线客服系统,编译后的二进制文件可直接使用无需搭开发环境,下载zip解压即可,仅依赖MySQL数据库,是一个开箱即用的全渠道在线客服系统,致力于帮助广大开发者/公司快速部署整合私有化客服功能。
开源地址:唯一客服(开源学习版)
官网地址:唯一客服官网