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

golang中channel什么时候会阻塞

在 Go 中,通道(channel)会在以下情况下阻塞:

1. 发送操作阻塞

  • 无缓冲通道: 当你向无缓冲通道发送数据时,如果没有其他 goroutine 读取数据,发送操作将阻塞。

    ch := make(chan int) // 无缓冲通道
    ch <- 1 // 阻塞,直到有接收者
    
  • 缓冲通道已满: 当缓冲通道的缓冲区已满时,尝试发送数据将阻塞,直到有空间可用。

    ch := make(chan int, 2) // 缓冲通道,大小为 2
    ch <- 1
    ch <- 2
    // ch <- 3 // 阻塞,直到有人接收
    

2. 接收操作阻塞

  • 无缓冲通道: 当你从无缓冲通道接收数据时,如果没有其他 goroutine 发送数据,接收操作将阻塞。

    ch := make(chan int) // 无缓冲通道
    val := <-ch // 阻塞,直到有人发送
    
  • 缓冲通道为空: 当尝试从缓冲通道接收数据时,如果通道为空,接收操作将阻塞,直到有数据可用。

    ch := make(chan int, 2) // 缓冲通道
    // ch <- 1
    // val := <-ch // 阻塞,直到有人发送数据
    

3. select 语句阻塞

  • select 会阻塞,直到其中一个 case 可执行。如果所有的 case 都不可执行(例如,所有的通道都没有数据可读或没有空间可写),则 select 将阻塞。

    select {
    case msg := <-ch1: // 如果 ch1 没有数据则阻塞fmt.Println(msg)
    case ch2 <- 2: // 如果 ch2 满则阻塞fmt.Println("Sent to ch2")
    }
    

4. 避免阻塞

  • 使用 default: 在 select 中添加 default 分支可以避免阻塞。

    select {
    case msg := <-ch:fmt.Println(msg)
    default:fmt.Println("No messages received")
    }
    

总结

通道的阻塞机制是 Go 实现并发的重要特性,它确保了数据的安全传递和同步。在使用通道时,理解何时会阻塞对于编写高效的并发程序至关重要。


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

相关文章:

  • TCP和UDP编程的学习
  • 如何在 3 分钟内免费在 AWS 上运行 RStudio
  • Redis 检查是否已经开启了持久化配置的几种方法
  • 看看人家写的,Controller太优雅了~【送源码】
  • MyBatis批量插入
  • 通过proxy和普通模式实现单例
  • HTML+JS谁是卧底游戏
  • Leetcode面试经典150题-300.最长递增子序列
  • C程序设计——运算符0
  • 掌握ThinkPHP6中的数据验证技巧,提升开发效率
  • uniapp快速回顾,新学websocket连接和BLE连接
  • 计算机网络参考模型
  • Ps:首选项 - 界面
  • 【鸿蒙学习】HarmonyOS应用开发者高级认证 - 应用性能优化一(界面层面)
  • R语言基于DeepTime进行时间尺度古生物与地质分析
  • 开源自动化测试工具MeterSphere
  • 探索CSS的:future-link伪类:选择指向未来文档的链接
  • SpringBoot获取不到Nacos配置信息报错,Nacos鉴权
  • 设计模式(3)结构型模式
  • leetcode977:有序数组的平方