free技术详解 lock_lock free的理解

free技术详解 lock_lock free的理解转自:http://www.isnowfy.com/understand-to-lock-free/以前一直不明白lockfree是什么,后来发现原来是完全理解错了概念,lockfree看到大家有的翻译为无锁,有的翻译为锁无关,其实用不用锁和lockfree是不相关的,用了锁也可能是lockfree,而不用锁有可能不是lockfree。一个lockfree的解释是一个“锁无关”的程序能…

大家好,又见面了,我是你们的朋友全栈君。

转自:http://www.isnowfy.com/understand-to-lock-free/

以前一直不明白lock free是什么,后来发现原来是完全理解错了概念,lock free看到大家有的翻译为无锁,有的翻译为锁无关,其实用不用锁和lock free是不相关的,用了锁也可能是lock free,而不用锁有可能不是lock free。

一个lock free的解释是

一个“锁无关”的程序能够确保执行它的所有线程中至少有一个能够继续往下执行。

其实看我们那副图就是说你的各个线程不会互相阻塞,那么你的程序才能成为lock free的。像我们平常用的互斥锁,当有线程获得锁,其他线程就被阻塞掉了,这里的问题就是如果获得锁的线程挂掉了,而且锁也没有释放,那么整个程序其实就被block在那了,而如果程序是lock free的那么即使有线程挂掉,也不影响整个程序继续向下进行,也就是系统在整体上而言是一直前进的。

那么,不用锁就是lock free的吗,一开始就提到了,不用锁也可能不是lock free的,举个例子

while (x == 0) {

x = 1-x;

}

在这里如果两个线程同时执行,可能同时进入while循环,然后x两次改变值之后,依然是0,那么两个线程就会一直互相在这里阻塞掉了,所以这里虽然没有锁,依然不是lock free的。

现在大家写lock free的时候一般都会使用CAS(compare and set)操作来写,因为现在很多的cpu都是支持CAS操作并作为原子操作来处理的,CAS操作一般是这样的

bool compare_and_swap (int *oldval, int *dest, int newval) {

if (*oldval == *dest) {

*dest = newval;

return true;

}

return false;

}

其实这样一个操作和乐观锁很像,并且操作简单,相应的比互斥锁的代价要小。所以现在大家都是喜欢用lock free的技术来提高系统的performance。

最后如果大家对于如何编写lock free的数据结构感兴趣的话,可以参考我后面给出的链接。

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/161680.html原文链接:https://javaforall.net

(0)
上一篇 2022年7月19日 下午12:16
下一篇 2022年7月19日 下午12:16


相关推荐

  • GirdView 通过 RenderControl 导出 excel 日期问题

    GirdView 通过 RenderControl 导出 excel 日期问题for(inti=0;i<gt.Rows.Count;i++){ gt.Rows[i].Cells[7].Text=Convert.ToDateTime(gt.Rows[i].Cells[7].Text).ToString("yyyy年MM月dd日HH:mm:ss");}

    2022年7月20日
    17
  • vb中adodc连接sql(如何用vb打印Access数据)

    本文实例讲述了使用ADODB.Connection连接access数据库的方法,驱动类型版本为:Microsoft.Jet.OLEDB.4.0。在VB的数据库操作中,连接数据库是第一步,也是最基本的,本文所述的这个例子,对于初学者学习如何在VB中连接Access数据库有着很好的借鉴参考价值。具体实现代码如下:VERSION5.00BeginVB.Form操作数据库Caption=…

    2022年4月17日
    51
  • Pycharm创建QT工具

    Pycharm创建QT工具安装工具包 pyqt5 和 PyQt5 tools 添加环境变量把上面变量添加到 Paty 中 Pycharm 创建 QT 工具先添加 Qt Designer 应用 FileDir 点击工具里面的 ExternalTool 若出现弹框报错解决方案是将 pyqt5 tools Qt plugins 文件夹进行复制 覆盖到 site packages pyqt5 tools Qt bin 目录下 覆盖后的文件夹如下 就可以打开应用使用 QT 应用先创建进行添加图片操作先创建文件名添加图片

    2026年3月27日
    2
  • 1Panel 一键安装 OpenClaw详细图文教程

    1Panel 一键安装 OpenClaw详细图文教程

    2026年3月13日
    8
  • 私有IP地址的意义及其范围

    私有IP地址的意义及其范围笔者在计算机网络的考试中 对有关私有 IP 地址的问题完全不了解 导致痛失很多分 所以考试之后对此进行了比较详细的查询 分享如下 IP 地址按用途 人为的 分为私有地址和公有地址两种 所谓私有地址就是在 A B C 三类 IP 地址中保留下来为企业内部网络分配地址时所使用的 IP 地址 私有地址主要用于在局域网中进行分配 在 Internet 上是无效的 这样可以很好地隔离局域网和 Internet 私有地址在公网上是不能被识别的 必须通过 NAT 将内部 IP 地址转换成公网上可用的 IP 地址 从而实现内部 IP 地址与外部公网的

    2026年3月16日
    2
  • 基于BGP协议的广域网流量调度SDN控制器在银行业的部署实践「建议收藏」

    基于BGP协议的广域网流量调度SDN控制器在银行业的部署实践「建议收藏」作者:王逊摘要:SDN作为网络自动化(NetworkAutomation)一种应用场景,从2009年Openflow的提出后在近几年已经进入到快速发展、现网部署阶段。SD-WAN实际上就是将SDN和网络自动化的思想和技…

    2025年9月24日
    5

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号