题目解析 GOLANG ROADMAP 社区
答案 (engine)
channel 实用于数据在多个协程中流动的场景,有很多理论利用:
① 工作定时
比方超时解决:
select {case <-time.After(time.Second):
定时工作
select {case <- time.Tick(time.Second)
② 解耦生产者和消费者
能够将生产者和消费者解耦进去,生产者只须要往 channel 发送数据,而消费者只管从 channel 中获取数据。
③ 管制并发数
以爬虫为例,比方须要爬取 1w 条数据,须要并发爬取以提高效率,但并发量又不能过大,能够通过 channel 来管制并发规模,比方同时反对 5 个并发工作:
ch := make(chan int, 5)
for _, url := range urls {go func() {
ch <- 1
worker(url)
<- ch
}
}
本文由:GOLANG ROADMAP 社区 公布