死锁

死锁是指两个或两个以上的协程的执行过程中,由于竞争资源或由于彼此通信而造成的一种阻塞的现象,若无外力作用,他们将无法推进下去。 (推荐学习:go)

常见的死锁

场景1:一个通道在一个go程读写

func main() {c:=make(chan int)c<-88<-c}

场景二:go程开启之前使用通道

func main() {c:=make(chan int)c<-88go func() {<-c}()}

场景三:通道1中调用了通道2,通道2中调用通道1

func main() {c1,c2:=make(chan int),make(chan int)go func() {for  {select{case <-c1:c2<-10}}}()for  {select{case <-c2:c1<-10}}}

死锁的出现的情况很多,但都不外乎是争抢资源和数据通信引起。

解决死锁的方法是加锁。

更多相关文章

  1. 详解 Golang 通道 Chan
  2. 摄像机通道号对接
  3. 使用 Thread Pool 不当引发的死锁
  4. 多线程之死锁就是这么简单
  5. Mysql 死锁引发的@Transactional 数据回滚
  6. 如何避免死锁
  7. 什么是死锁?
  8. Java 死锁范例以及如何分析死锁
  9. 我需要一个django-芹菜守护进程来监听特定的rabbitmq通道

随机推荐

  1. 老家被拆了,我的少年记忆也无处安放了
  2. Redux源码解读
  3. 扒一扒 @SpringBootApplication 注解背后
  4. 解密ThreadLocal
  5. JS内存泄漏排查方法
  6. 函数和递归
  7. 视频演示:好家伙,我直接好家伙!
  8. 深入React
  9. 今晚,我等你 ~
  10. 分布式系统的事务处理