ICode9

精准搜索请尝试: 精确搜索
首页 > 其他分享> 文章详细

GO语言锁的处理机制(简单描述,不喜勿喷,欢迎纠正)

2021-09-28 17:01:19  阅读:172  来源: 互联网

标签:纠正 队列 goroutine 获取 饥饿 GO 不喜 争抢 等待


获取锁的机制 如果当前没有goroutine获取到锁则直接获取 如果锁已经被获取,则goroutine会被休眠加入一个先进先出的队列   解锁的机制 1.尝试解锁,如果本来就没有加锁,则抛异常 2.正常解锁后,通过信号量的方式唤醒等待中的goroutine,开始争抢锁(因为新的goroutine正在cpu中运行,所以等待中的goroutine需要一个唤醒的过程这就导致速度慢了,一直被新的goroutine获取锁),  如果争抢锁的goroutine首次没有获取到锁,则会通过一定次数的自旋来不断的获取锁,争抢结束后(其中一个goroutine获取到了锁),剩余的goroutine会加入到等待队列重新休眠,  如果不是首次加入队列,则会被加入到队列的首位(如果是饥饿模式,新来的goroutine不会参与争抢,直接加入到等待队列,下面会介绍饥饿模式)     解决饥饿 因为新来的 goroutine 也参与竞争,有可能每次都会被新来的 goroutine 获取到锁(因为新来的goroutine正在cpu中运行,所以速度更快), 在极端情况下,等待中的 goroutine 可能会一直获取不到锁,这就是饥饿问题。在这样的情况下,锁的争抢就会进入饥饿模式。     在饥饿模式中,等待中的goroutine等待时间超过阈值1毫秒的情况下,就可以优先获取到锁,之后锁的争抢会回到正常模式   GO语言中锁的源码较长,几乎无法阅读,所以理解机制即可。 整个的流程差不多是上面说的这样,如果有错误,请大家纠正。

标签:纠正,队列,goroutine,获取,饥饿,GO,不喜,争抢,等待
来源: https://www.cnblogs.com/WORDPAD/p/15348749.html

本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享;
2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关;
3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关;
4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除;
5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。

专注分享技术,共同学习,共同进步。侵权联系[81616952@qq.com]

Copyright (C)ICode9.com, All Rights Reserved.

ICode9版权所有