Go语言使用goroutine及通道实现并发详解
作者:陈博士
使用通道接收数据
在上一篇文章中介绍了通道以及使用通道发送数据,本篇接着了解通道的基本内容,如何使用通道接收数据;
通道的接收同样使用"<-"操作符;
使用通道接收数据的特性如下:
- 通道的发送和接收操作在不同的两个goroutine间进行,由于通道中的数据在没有接收方接收时会持续阻塞,所以通道的接收必定在另外一个goroutine中进行;
- 如果在接收方接收时,通道中没有发送方发送数据,则接收方也会发生阻塞,直到发送方发送消息为止;
- 通道一次只能接收一个元素数据;
通道的数据接收有四种写法,接下来一一进行介绍
阻塞接收数据
阻塞模式在接收数据时,将接收变量作为"<-"操作符的左值,格式如下:
data := <-ch
执行该语句时将会阻塞,直到接收到数据并赋值给data变量
非阻塞接收数据
在使用非阻塞方式从通道接收数据时,语句不会发生阻塞,格式如下
data, ok := <-ch
data:接收到的数据,在未接收到数据时data为通道类型的零值
ok:是否接收到数据
非阻塞的通道接收方法,可能造成高的CPU占用,因此使用非常少,如果需要实现接收超时检测,则需要配合select和计时器进行;
接收任意数据,忽略掉接收的数据
写法如下:
<-ch
使用上面的这种写法,会发生阻塞,直到接收到消息,但是通道在接收到数据后会将其忽略掉;这个方式实际上只是通过通道在goroutine间阻塞收发,从而实现并发同步;
使用通道做并发同步的示例如下图所示:
循环接收数据
通道的数据接收可以借用for-range语句进行多个元素的接收操作,格式如下:
for data := range ch{ }
通道ch是可以被遍历的,遍历的结果就是接收到的数据,数据类型就是通道的数据类型,通过for遍历获得的变量只有一个,即上面例子中的data;
遍历通道数据的示例如下图所示:
通道可以在两个goroutine之间通过传递一个指定类型的值来同步运行和通讯,操作符"<-"用于指定通道的方向、发送和接收,如果未指定方向,则为双向通道;
ch <- v 把v发送到通道ch中
v := <-ch 从ch接收数据,并把值赋给v
下面列举一个示例通过两个goroutine计算数字之和,如下图所示:
以上就是通道接收数据的相关内容,更多关于Go goroutine通道并发的资料请关注脚本之家其它相关文章!