Go 语言学习之 goroutine 和 channel

简介: Go 语言学习之 goroutine 和 channel

01

goroutine


当一个 go 程序运行时,调用 main 函数入口的 goroutine 是主 goroutine,我们还可以使用关键字 go 创建新的 goroutine。在 Go 语言中,创建 goroutine 的语法很简单,只需要在函数或方法调用前加上 go 关键字。


02

channel


channel 是可以让一个 goroutine 发送特定的值到另一个 goroutine 的通信机制。Go 官方鼓励使用 CSP 并发编程风格,以通信代替内存共享,实现并发安全。


与 map 类似,channel 也是使用内置函数 make 创建。channel 是引用类型,它的零值是 nil,channel 可以和 nil 进行比较,相同类型的 channel 可以使用 “==” 符号进行比较。


使用内置函数 make 创建 channel 时,有两个参数,第一个参数是元素类型,第二个可选参数是 channel 的容量。不设置 channel 容量称为无缓冲 channel,设置 channel 容量称为缓冲 channel。无缓冲 channel 是一种阻塞的同步 channel。内置函数 cap 可以获取缓冲 channel 的容量,内置函数 len 可以获取缓冲 channel 的元素个数。


03

channel 操作


channel 操作有三种,分别是 send、receive 和 close。send 操作可以从一个执行的 goroutine 传输一个值到另一个执行 receive 操作的 goroutine。


send 操作和 receive 操作都使用 “<-” 操作符,在 send 语句中,channel 和值分别在操作符左右两边,在 receive 语句中,操作符放在 channel 操作数的前面。


close 操作通过设置一个标志位来表示当前值已经 send 完毕,channel 不会再被 send 值了,close 操作后的 send 操作将导致宕机。在一个已经执行 close 操作的 channel 上执行 receive 操作,将获取这个 channel 上所有已经 send 的值,直到 channel 为空。


缓冲 channel 的 send 操作在队列的尾部插入一个元素,receive 操作在队列的头部移除一个元素。如果缓冲 channel 容量占满,send 操作会阻塞所在的 goroutine,直到另一个 goroutine 对它执行 receive 操作来腾出可用空间。如果缓冲 channel 是空的,receive 操作的 goroutine 阻塞,直到另一个 goroutine 在这个缓冲 channel 上 send 数据。


需要注意的是,如果在同一个缓冲 channel 上执行 send 操作和 receive 操作,是将缓冲 channel 错误地作为队列使用了。在实际项目开发中,send 操作和 receive 操作是由不同的 goroutine 执行的。


无缓冲 channel 的每一次 send 操作都对应一次 receive 操作,实现强同步。缓冲 channel 的 send 操作和 receive 操作是解耦的。我们如果事先可以知道需要 send 的值的数量上限,可以创建一个容量是使用上限的缓冲 channel,在 receive 第一个值前就完成了所有的 send 操作。


使用缓冲 channel,需要注意 send 操作和 receive 操作的 goroutine 的执行效率,否则会影响性能。


04

select 多路复用


select 语句类似 switch 语句,有至少一个 case 分支,和一个可选的默认分支 default。每一个 case 分支指定一次通信(在一些 channel 上执行 send 操作或 receive 操作)和关联的一段代码块。


select 一直处于等待状态,直到一次通信可以符合条件执行某一个或多个 case 分支的代码块,然后 select 执行这次通信,并执行对应的 case 分支,其他的通信将不会发生,select 如果没有可以符合条件执行的 case 分支,它将永远处于等待状态。select 如果同时符合多个 case 分支执行,select 将随机选择一个 case 分支执行。


select  如果有可选默认分支 default,在没有通信可以符合条件执行某一个 case 分支时,它将执行默认分支 default 的代码块。





目录
相关文章
|
4天前
|
存储 监控 算法
员工上网行为监控中的Go语言算法:布隆过滤器的应用
在信息化高速发展的时代,企业上网行为监管至关重要。布隆过滤器作为一种高效、节省空间的概率性数据结构,适用于大规模URL查询与匹配,是实现精准上网行为管理的理想选择。本文探讨了布隆过滤器的原理及其优缺点,并展示了如何使用Go语言实现该算法,以提升企业网络管理效率和安全性。尽管存在误报等局限性,但合理配置下,布隆过滤器为企业提供了经济有效的解决方案。
32 8
员工上网行为监控中的Go语言算法:布隆过滤器的应用
|
24天前
|
存储 Go 索引
go语言中数组和切片
go语言中数组和切片
37 7
|
23天前
|
Go 开发工具
百炼-千问模型通过openai接口构建assistant 等 go语言
由于阿里百炼平台通义千问大模型没有完善的go语言兼容openapi示例,并且官方答复assistant是不兼容openapi sdk的。 实际使用中发现是能够支持的,所以自己写了一个demo test示例,给大家做一个参考。
|
24天前
|
程序员 Go
go语言中结构体(Struct)
go语言中结构体(Struct)
99 71
|
23天前
|
存储 Go 索引
go语言中的数组(Array)
go语言中的数组(Array)
102 67
|
24天前
|
存储 Go
go语言中映射
go语言中映射
35 11
|
25天前
|
Go 索引
go语言使用range关键字
go语言使用range关键字
29 7
|
25天前
|
Go 索引
go语言修改元素
go语言修改元素
29 6
|
1天前
|
监控 算法 安全
解锁企业计算机监控的关键:基于 Go 语言的精准洞察算法
企业计算机监控在数字化浪潮下至关重要,旨在保障信息资产安全与高效运营。利用Go语言的并发编程和系统交互能力,通过进程监控、网络行为分析及应用程序使用记录等手段,实时掌握计算机运行状态。具体实现包括获取进程信息、解析网络数据包、记录应用使用时长等,确保企业信息安全合规,提升工作效率。本文转载自:[VIPShare](https://www.vipshare.com)。
11 0
|
15天前
|
Go 数据安全/隐私保护 UED
优化Go语言中的网络连接:设置代理超时参数
优化Go语言中的网络连接:设置代理超时参数