乐趣区

关于go:Go题库11channel的应用场景

题目解析 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 社区 公布

退出移动版