温馨提示×

温馨提示×

您好,登录后才能下订单哦!

密码登录×
登录注册×
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》

Go语言怎么使用goroutine及通道实现并发

发布时间:2022-08-25 10:47:48 来源:亿速云 阅读:160 作者:iii 栏目:开发技术

今天小编给大家分享一下Go语言怎么使用goroutine及通道实现并发的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起来了解一下吧。

使用通道接收数据

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

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

  • 通道的发送和接收操作在不同的两个goroutine间进行,由于通道中的数据在没有接收方接收时会持续阻塞,所以通道的接收必定在另外一个goroutine中进行;

  • 如果在接收方接收时,通道中没有发送方发送数据,则接收方也会发生阻塞,直到发送方发送消息为止;

  • 通道一次只能接收一个元素数据;

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

阻塞接收数据

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

data := <-ch

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

非阻塞接收数据

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

data, ok := <-ch

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

ok:是否接收到数据

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

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

写法如下:

<-ch

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

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

Go语言怎么使用goroutine及通道实现并发

循环接收数据

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

for data := range ch{
}

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

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

Go语言怎么使用goroutine及通道实现并发

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

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

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

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

Go语言怎么使用goroutine及通道实现并发

以上就是“Go语言怎么使用goroutine及通道实现并发”这篇文章的所有内容,感谢各位的阅读!相信大家阅读完这篇文章都有很大的收获,小编每天都会为大家更新不同的知识,如果还想学习更多的知识,请关注亿速云行业资讯频道。

向AI问一下细节

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

AI