Go语言使用goroutine及通道实现并发详解

使用通道接收数据

在上一篇文章中介绍了通道以及使用通道发送数据,本篇接着了解通道的基本内容,如何使用通道接收数据;

通道的接收同样使用"<-"操作符;

使用通道接收数据的特性如下:

  • 通道的发送和接收操作在不同的两个goroutine间进行,由于通道中的数据在没有接收方接收时会持续阻塞,所以通道的接收必定在另外一个goroutine中进行;
  • 如果在接收方接收时,通道中没有发送方发送数据,则接收方也会发生阻塞,直到发送方发送消息为止;
  • 通道一次只能接收一个元素数据;

通道的数据接收有四种写法,接下来一一进行介绍

阻塞接收数据

阻塞模式在接收数据时,将接收变量作为"<-"操作符的左值,格式如下:

data := <-ch

执行该语句时将会阻塞,直到接收到数据并赋值给data变量

非阻塞接收数据

在使用非阻塞方式从通道接收数据时,语句不会发生阻塞,格式如下

data, ok := <-ch

data:接收到的数据,在未接收到数据时data为通道类型的零值

ok:是否接收到数据

非阻塞的通道接收方法,可能造成高的CPU占用,因此使用非常少,如果需要实现接收超时检测,则需要配合select和计时器进行;

接收任意数据,忽略掉接收的数据

写法如下:

<-ch

使用上面的这种写法,会发生阻塞,直到接收到消息,但是通道在接收到数据后会将其忽略掉;这个方式实际上只是通过通道在goroutine间阻塞收发,从而实现并发同步;

使用通道做并发同步的示例如下图所示:

Go语言使用goroutine及通道实现并发详解_第1张图片

循环接收数据

通道的数据接收可以借用for-range语句进行多个元素的接收操作,格式如下:

for data := range ch{
}

通道ch是可以被遍历的,遍历的结果就是接收到的数据,数据类型就是通道的数据类型,通过for遍历获得的变量只有一个,即上面例子中的data;

遍历通道数据的示例如下图所示:

Go语言使用goroutine及通道实现并发详解_第2张图片

通道可以在两个goroutine之间通过传递一个指定类型的值来同步运行和通讯,操作符"<-"用于指定通道的方向、发送和接收,如果未指定方向,则为双向通道;

ch <- v       把v发送到通道ch中

v := <-ch     从ch接收数据,并把值赋给v

下面列举一个示例通过两个goroutine计算数字之和,如下图所示:

Go语言使用goroutine及通道实现并发详解_第3张图片

以上就是通道接收数据的相关内容,更多关于Go goroutine通道并发的资料请关注脚本之家其它相关文章!

你可能感兴趣的:(Go语言使用goroutine及通道实现并发详解)