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

2022-08-24 17:44:02
目录
使用通道接收数据阻塞接收数据非阻塞接收数据接收任意数据,忽略掉接收的数据循环接收数据

使用通道接收数据

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

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

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

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

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

    阻塞接收数据

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

    data := <-ch
    

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

    非阻塞接收数据

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

    data,>

    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通道并发的资料请关注易采站长站其它相关文章!