当前位置: 首页 > news >正文

golang的channel阻塞例子分享

在这段 Go 代码中,确实会发生阻塞,以下是详细的解释:

func main() {ch := make(chan int, 1)go func() {// 这里接收数据并打印value := <-chfmt.Println("Received:", value)value = <-chfmt.Println("Received:", value)}()// 主 goroutine 发送数据ch <- 1fmt.Println("123456")
}

代码执行流程:

  1. 创建了一个带缓冲区的通道 ch,缓冲区大小为 1。
  2. 创建了一个新的 goroutine,在这个 goroutine 内部,有两次从 ch 通道接收数据的操作。
  3. 主 goroutine 通过 ch <- 1 向通道发送了一个值 1
  4. 主 goroutine 然后打印 "123456"

阻塞分析:

  • ch <- 1 发送操作会将值 1 发送到 ch 通道。由于 ch 是一个带缓冲的通道,并且缓冲大小为 1,所以第一次发送值 1 不会阻塞,它会直接被存入通道。

  • 在子 goroutine 中,value := <-ch 这行代码会从通道中接收一个值,成功接收后打印 "Received: 1"

  • 子 goroutine 接下来要执行 value = <-ch,但此时通道中已经没有值了,通道也没有关闭,因此这个接收操作会阻塞,等待下一个值被发送到通道中。

打印顺序:

  • 在主 goroutine 中,ch <- 1 发送成功后,主 goroutine 会继续执行 fmt.Println("123456")

  • 因为主 goroutine 和子 goroutine 是并发执行的,主 goroutine 不会被子 goroutine 的阻塞所影响,所以 "123456" 会被正常打印。

结论:

  • value = <-ch 会被阻塞,因为通道没有更多的数据可以接收。
  • "123456" 会被打印,因为主 goroutine 不会因为子 goroutine 的阻塞而被阻塞。

http://www.mrgr.cn/news/566.html

相关文章:

  • 【图像去雾系列】使用SSR/MSR/MSRCR/MSRCP/automatedMSRCR算法对单图像进行图像增强,达到去雾效果
  • 给既有exe程序添加一机一码验证
  • 第R1周: RNN-心脏病预测
  • BM100 设计LRU缓存结构
  • 案例分享—国外毛玻璃效果UI设计案例
  • 智慧安防/一网统管/视频监控EasyCVR视频汇聚平台的视频轻量化特点及应用
  • JavaScript初级——语句
  • 【leetcode面试题】java完成leetcode面试150题
  • 【k8s】pod和serviceaccount关系
  • 面向自动驾驶保证车辆转向稳定性的模型预测控制
  • web开发,过滤器,前后端交互
  • 如何有效利用渗压计来避免溃坝风险
  • 【CMake】学习笔记2
  • 物流抓取机器人整体设计方案
  • NacosRce到docker逃逸实战
  • 解密未来:ARIMA模型在时间序列预测中的卓越应用
  • Vue3列表(List)
  • TED: 1靶场复现【附代码】(权限提升)
  • 在java环境下判断某个元素是否存在
  • Python基础知识点--总结