关于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社区 公布

评论

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

这个站点使用 Akismet 来减少垃圾评论。了解你的评论数据如何被处理