• 博客园logo
  • 会员
  • 众包
  • 新闻
  • 博问
  • 闪存
  • 赞助商
  • HarmonyOS
  • Chat2DB
    • 搜索
      所有博客
    • 搜索
      当前博客
  • 写随笔 我的博客 短消息 简洁模式
    用户头像
    我的博客 我的园子 账号设置 会员中心 简洁模式 ... 退出登录
    注册 登录
Eysa
博客园    首页    新随笔    联系   管理    订阅  订阅

Go 初体验 - 死锁的几种情况

每个语言都涉及锁及死锁,本文总结了下 go 语言集中死锁的情况

go 语言里,channel 是一个重要的对象和概念,它是通信的基础实现

如何实例化:

ch := make(chan int)

由 channel 通信引起的死锁共有3种:

第一种是因为给 ch 推送消息而没有读取,这时会阻塞当前携程,如果是 main,那么编译就报错 deadlock

第二种是因为读取 ch1 时 ch1 又在读取 ch2,而 ch2 并没有推送消息,故,死锁。解决办法就是放开注释那行代码就OK

第三种是因为读 quit 时被 c <- 1 这行代码阻塞了,c 并没有被读取故宿主被阻塞发生死锁。解决办法就是放开注释行代码就OK

第一种只是演示,实际编码不会有这种情况,也不推荐

总结:

go 语言里的 channel 只有推送和读取同时存在时才不会发生死锁,只读或只推都会发生死锁。

不要通过共享内存来通信,而应该通过通信来共享内存

 

posted @ 2019-02-20 14:05  Eysa  阅读(871)  评论(0)    收藏  举报
刷新页面返回顶部
博客园  ©  2004-2025
浙公网安备 33010602011771号 浙ICP备2021040463号-3