在 go 语言中,channel 作为一种并发通信机制,可以通过 select 语句与多个 channel 进行通信。虽然在某些情况下只有单个 channel 的场景,使用 select 与直接接收并没有明显区别,但当需要处理多个 channel 时,select 就会展现其优势。
示例对比
// 直接接收 func myselect() { ch := make(chan int, 10) a := <-ch fmt.println(a) }
登录后复制
// 使用 select func myselect() { ch := make(chan int, 10) select { case a := <-ch: fmt.println(a) } }
登录后复制
这两个示例分别使用直接接收和 select 接收 channel 数据,在只有单个 channel 的情况下,运行结果相同。
select 的优势
然而,当涉及多个持续写入数据的 channel 时,情况就不同了。使用直接接收会阻塞后续代码的执行,而使用 select 可以同时处理多个 channel 的输入。
例如,以下代码使用 for 循环从持续写入数据的 channel 中读取数据:
func myselect(ch chan int) { for { a := <-ch fmt.println(a) } }
登录后复制
为了同时处理另一个 channel,我们需要使用 select:
func MySelect(ch chan int, ch2 chan int) { for { select { case a := <-ch: fmt.Println(a) case b := <-ch2: fmt.Println(b) } } }
登录后复制
无论哪个 channel 先有数据被接收,都不会产生阻塞。这确保了并发处理多个 channel 的效率。
© 版权声明
文章版权归作者所有,未经允许请勿转载。
【小浪云服务商 - 服务器12元起 - 挂机宝5元起】
THE END
暂无评论内容