iis服务器助手广告广告
返回顶部
首页 > 资讯 > 后端开发 > GO >详解Golang并发操作中常见的死锁情形
  • 239
分享到

详解Golang并发操作中常见的死锁情形

2024-04-02 19:04:59 239人浏览 八月长安
摘要

目录第一种情形:无缓存能力的管道,自己写完自己读 第二种情形:协程来晚了 第三种情形:管道读写时,相互要求对方先读/写 第四种情形:读写锁相互阻塞,形成隐形死锁 什么是死锁,在Go的

什么是死锁,在Go的协程里面死锁通常就是永久阻塞了,你拿着我的东西,要我先给你然后再给我,我拿着你的东西又让你先给我,不然就不给你。我俩都这么想,这事就解决不了了。

第一种情形:无缓存能力的管道,自己写完自己读

先上代码:


func main() {
    ch := make(chan int, 0)
​
    ch <- 666
    x := <- ch
    fmt.Println(x)
}

我们可以看到这是一个没有缓存能力的管道,然后往里面写666,然后就去管道里面读。这样肯定会出现问题啊!一个无缓存能力的管道,没有人读,你也写不了,没有人写,你也读不了,这正是一种死锁!

fatal error: all goroutines are asleep - deadlock!

解决办法很简单,开辟两条协程,一条协程写,一条协程读。

第二种情形:协程来晚了


func main() {
    ch := make(chan int,0)
    ch <- 666
    go func() {
        <- ch
    }()
}

我们可以看到,这条协程开辟在将数字写入到管道之后,因为没有人读,管道就不能写,然后写入管道的操作就一直阻塞。这时候你就有疑惑了,不是开辟了一条协程在读吗?但是那条协程开辟在写入管道之后,如果不能写入管道,就开辟不了协程。

第三种情形:管道读写时,相互要求对方先读/写

如果相互要求对方先读/写,自己再读/写,就会造成死锁。


func main() {
    chHusband := make(chan int,0)
    chWife := make(chan int,0)
​
    go func() {
        select {
        case <- chHusband:
            chWife<-888
        }
    }()
​
    select {
        case <- chWife:
            chHusband <- 888
    }
}

先来看看老婆协程,chWife只要能读出来,也就是老婆有钱,就给老公发个八百八十八的大红包。

再看看老公的协程,一看不得了,咋啦?老公也说只要他有钱就给老婆包个八百八十八的大红包。

两个人都说自己没钱,老公也给老婆发不了红包,老婆也给老公发不了红包,这就是死锁!

第四种情形:读写锁相互阻塞,形成隐形死锁

先来看一看代码:


func main() {
    var rmw09 sync.RWMutex
    ch := make(chan int,0)
​
    go func() {
        rmw09.Lock()
        ch <- 123
        rmw09.Unlock()
    }()
​
    go func() {
        rmw09.RLock()
        x := <- ch
        fmt.Println("读到",x)
        rmw09.RUnlock()
    }()
​
    for {
        runtime.GC()
    }
}

这两条协程,如果第一条协程先抢到了只写锁,另一条协程就不能抢只读锁了,那么因为另外一条协程没有读,所以第一条协程就写不进。

如果第二条协程先抢到了只读锁,另一条协程就不能抢只写锁了,那么因为另外一条协程没有写,所以第二条协程就读不到。

到此这篇关于详解golang并发操作中常见的死锁情形的文章就介绍到这了,更多相关Golang 并发死锁内容请搜索编程网以前的文章或继续浏览下面的相关文章希望大家以后多多支持编程网!

您可能感兴趣的文档:

--结束END--

本文标题: 详解Golang并发操作中常见的死锁情形

本文链接: https://www.lsjlt.com/news/134183.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • 详解Golang并发操作中常见的死锁情形
    目录第一种情形:无缓存能力的管道,自己写完自己读 第二种情形:协程来晚了 第三种情形:管道读写时,相互要求对方先读/写 第四种情形:读写锁相互阻塞,形成隐形死锁 什么是死锁,在Go的...
    99+
    2024-04-02
  • Golang并发操作中常见的读写锁详析
    互斥锁简单粗暴,谁拿到谁操作。今天给大家介绍一下读写锁,读写锁比互斥锁略微复杂一些,不过我相信我们今天能够把他拿下! golang读写锁,其特征在于 读锁:可以同时进行多个...
    99+
    2024-04-02
  • Golang中常见的并发编程模式详解
    Golang中常见的并发编程模式详解 随着软件开发行业的不断发展,对高性能和高并发的需求也越来越迫切。并发编程已经成为现代软件开发中不可或缺的一部分,而Golang(Go语言)作为一种...
    99+
    2024-02-28
    模式 golang 并发 go语言
  • Python 模拟死锁的常见实例详解
    目录前言模拟死锁1:线程等待本身模拟死锁2:线程互相等待模拟死锁3:以错误的顺序获取锁模拟死锁4:锁未释放总结前言 常见的例子是在银行账户上:假如要在两个银行账户之间执行交易,你必须...
    99+
    2024-04-02
  • MySQL并发时经典常见的死锁原因有哪些
    这篇文章主要介绍了MySQL并发时经典常见的死锁原因有哪些,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。1、mysql都有什么锁?MySQL...
    99+
    2024-04-02
  • Golang函数并发编程中的死锁处理
    死锁是一种并发编程中的状态,其中多个进程或线程等待对方释放资源,导致程序无法继续进行。go 提供了以下机制来处理死锁:mutex 和通道:用于确保仅一个 goroutine 每次都能访问...
    99+
    2024-04-17
    并发编程 死锁处理 golang
  • Oracle常见死锁发生的原因以及解决方法
    一.删除和更新之间引起的死锁 造成死锁的原因就是多个线程或进程对同一个资源的争抢或相互依赖。这里列举一个对同一个资源的争抢造成死锁的实例。 CREATE ...
    99+
    2024-04-02
  • golang函数并发控制中死锁与饥饿的预防与解决
    go 中死锁和饥饿:预防与解决死锁:协程相互等待而无法进行的操作,使用 runtime.setblockprofilerate 函数检测。预防死锁:使用细粒度加锁、超时、无锁数据结构,防...
    99+
    2024-04-24
    死锁 饥饿 golang
  • 操作系统线程管理中的死锁问题:识别和解决并发的陷阱
    死锁是并发编程中常见且棘手的问题,它会导致两个或多个线程无限期地等待彼此的资源。在操作系统线程管理中,死锁可以冻结整个系统,导致严重的后果。本文将深入探讨死锁问题,提供识别和解决死锁的有效策略。 死锁的产生: 死锁通常发生在以下四个条件...
    99+
    2024-03-04
    死锁、操作系统、并发、进程、线程
  • Windows系统中常见的死机情况与解决方法
    在电脑使用过程中,我们经常会遇到死机的情况,而死机伴随者电脑操作系统,从一开始的Windows图形化操作系统开始,就一直有这样的情况,一直到Windows 7乃至泄漏版本的Windows 8一直存在。   为什么一直解决...
    99+
    2023-05-25
    Windows 死机 情况 解决 系统
  • Java学习笔记:如何解决Load并发操作中的常见问题?
    在Java开发中,Load并发操作是非常常见的一种操作。然而,由于并发操作的特殊性质,很容易出现一些常见的问题。在本文中,我们将介绍一些常见的Load并发操作问题,并提供一些解决方案和演示代码。 线程安全问题 在并发操作中,线程安全是...
    99+
    2023-09-09
    学习笔记 load 并发
  • Golang中除法操作的常见错误及解决方法
    Golang中除法操作的常见错误及解决方法 在Golang中,除法操作是我们在日常编程中经常会遇到的运算之一。然而,有时候在进行除法操作的过程中,我们可能会遇到一些常见的错误,这些错误...
    99+
    2024-02-22
    错误 golang 除法
  • Java 内存模型与死锁:深入理解并发编程中的死锁问题
    Java 内存模型(JMM)是一套规范,它定义了 Java 程序中变量是如何在多个线程之间共享的。JMM 规定了线程如何从主内存中读取和写入变量,以及如何将变量的值存储到主内存中。 死锁是并发编程中常见的一种问题,它发生在两个或多个线程...
    99+
    2024-02-04
    Java 内存模型 死锁 并发编程 同步 等待 通知 中断
  • Python常见文件操作的示例详解
    目录从文件中读取数据为什么要提供文件路径逐行读取创建一个包含文件各行内容的列表使用文件中的内容包含千位以上的大型文件圆周率中包含你的生日吗写入文件附加到文件从文件中读取数据 1:读取...
    99+
    2024-04-02
  • 操作系统线程管理中的死锁问题:探寻并发执行的陷阱
    死锁的定义和原因 死锁是一种系统状态,在这个状态下,多个线程或进程相互等待对方的资源,导致所有线程或进程都无法继续执行。死锁的发生通常是由于以下原因: 互斥资源:当多个线程或进程试图访问同一资源时,需要互斥机制来确保该资源一次只能被一个...
    99+
    2024-04-02
  • Golang的高并发场景中如何处理死锁和饥饿问题?
    死锁与饥饿在 go 并发编程中的成因和解决方法:死锁:由递归锁引起,避免方法是采用死锁避免算法。饥饿:由优先级反转引起,解决方法是使用优先级继承机制,让低优先级线程暂时获取高优先级线程的...
    99+
    2024-05-10
    死锁 饥饿 golang
  • 解析golang中的并发安全和锁问题
    1. 并发安全 package main import ( "fmt" "sync" ) var ( sum int wg sync.Wa...
    99+
    2024-04-02
  • 基于多线程并发的常见问题(详解)
    一 概述1.volatile保证共享数据一旦被修改就会立即同步到共享内存(堆或者方法区)中。2.线程访问堆中数据的过程线程在栈中建立一个数据的副本,修改完毕后将数据同步到堆中。3.指令重排为了提高执行效率,CPU会将没有依赖关系的指令重新排...
    99+
    2023-05-31
    多线程 并发 线程并发
  • 如何解决 C++ 多线程编程中常见的死锁问题?
    如何解决 c++++ 多线程编程中的常见死锁问题?避免死锁的技术:加锁顺序:始终以相同的顺序获取锁。死锁检测:使用算法检测并解决死锁。超时:为锁设置超时值,防止线程无限期等待。优先级反转...
    99+
    2024-05-13
    多线程编程 死锁 c++
  • MySQL中增删改查操作与常见陷阱详解
    目录本文导读一、mysql的增删改查1、insert语句2、delete语句3、update语句原理4、select二、15种MySQL数据操作语句1、REPLACE语句2、CALL语句3、TABLE语句4、W...
    99+
    2024-04-02
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作