非公平锁比公平锁高效的原因

阅读: 评论:0

非公平锁比公平锁高效的原因

非公平锁比公平锁高效的原因

什么是公平与非公平?

大白话简单来说,公平锁就相当于是正常生活购物场景中的排队结账,排好队一个接一个来抢占一个收银台;非公平锁就是一窝蜂地争抢着结账,谁先抢到就给谁结账。

按照生活常识来说,明显是排队效率比较高。

更高效的原因

在计算机世界中,对于Java而言,用户线程和系统线程是属于1:1的对应关系,线程切换存在【执行现场保存和恢复】,这个过程是非常耗费时间(在许多情况下,线程切换的时间远远大于代码执行的时间)。因此,如果一个线程在running期间直接抢占到锁资源,就不需要进行【恢复现场】操作,也就可以更快地执行业务代码。相反地,如果是一个就绪态的线程想要获得锁资源,首先需要恢复现场,之后争抢锁(可能成功也可能失败),此时就已经浪费了大量的CPU,只有在获取锁成功后才能继续执行业务代码。
总的来说,主要高效的原因就在于需不需要进行现场恢复和不同态之间切换。

仅属个人理解,如有错误,还望大佬多多指教。

本文发布于:2024-01-28 23:56:10,感谢您对本站的认可!

本文链接:https://www.4u4v.net/it/170645737311225.html

版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系,我们将在24小时内删除。

标签:公平   高效   原因
留言与评论(共有 0 条评论)
   
验证码:

Copyright ©2019-2022 Comsenz Inc.Powered by ©

网站地图1 网站地图2 网站地图3 网站地图4 网站地图5 网站地图6 网站地图7 网站地图8 网站地图9 网站地图10 网站地图11 网站地图12 网站地图13 网站地图14 网站地图15 网站地图16 网站地图17 网站地图18 网站地图19 网站地图20 网站地图21 网站地图22/a> 网站地图23