最新下载
热门教程
- 1
- 2
- 3
- 4
- 5
- 6
- 7
- 8
- 9
- 10
Go语言使用goroutine及通道实现并发解析
时间:2022-08-25 编辑:袖梨 来源:一聚教程网
本篇文章小编给大家分享一下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语言实现文件上传代码示例
相关文章
- Golang中的内存逃逸解析 10-18
- Go语言制作svg格式树形图代码示例 09-05
- Go保证并发安全底层实现代码解析 09-02
- Go REFLECT Library反射类型代码解析 09-01
- Golang单元测试和基准测试代码实例 08-24
- Golang官方限流器库实现限流代码示例 08-18