volatile关键字讨论

在这里插入图片描述
而通过上面的讨论之后,看了另外一篇讨论的文章
其中提到如下:
在这里插入图片描述
确实,其中提到了声明了vlatile之后,编译不对该变量做出任何上下文有关的优化,也就是其成了“可能是容易变的”,也就不能优化入寄存器,但其不能保证多线程所需要的【实际执行时的顺序符合预期】,也就是没有同步的语义在里面。依然在多线程上略微显得有些乏力。
还可以说一个很直观的历史因素——volatile关键字出现时,多核cpu和线程都还没出现的,它的出现和并发编程毫无关系,能凑巧解决一些并发问题也只是撞大运
文章详情可以看
谈谈 C/C++ 中的 volatile - 孟晨的文章 - 知乎 https://zhuanlan.zhihu.com/p/33074506。
但是有些情况可以例外,其例子可能执行能够表现为正确性,就是文章中所提到的:
在这里插入图片描述
此外,对于double checked lock为啥不可靠,也和这个有一些关系吧?
好像是x86平台下没有问题,因为可以ss不乱序,而只是sl乱序,所以和文中实例一样。
陈硕在其文中对DCL有以下说法:https://www.cs.umd.edu/~pugh/java/memoryModel/DoubleCheckedLocking.html
https://blog.csdn.net/weeniebear/article/details/8796443 这边博客把double checked lock讲的清清楚楚,由于jave5已经扩展了volatile语意,那么其double checked lock是可靠的,而C++没有这样保证,所以不能够保证正确性。
在这里插入图片描述

文章中还提到了一个问题:
在这里插入图片描述
那么jave中的volatile是什么呢?其提供了内存屏障,那她又是干什么的呢?
除此之外,其么缓存一致性协议mesi之间的关系又是什么呢?
这些都可以在一下文章中找找答案:
https://blog.csdn.net/org_hjh/article/details/109626607
https://www.zhihu.com/question/296949412

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
编译原理是计算机专业的一门核心课程,旨在介绍编译程序构造的一般原理和基本方法。编译原理不仅是计算机科学理论的重要组成部分,也是实现高效、可靠的计算机程序设计的关键。本文将对编译原理的基本概念、发展历程、主要内容和实际应用进行详细介绍编译原理是计算机专业的一门核心课程,旨在介绍编译程序构造的一般原理和基本方法。编译原理不仅是计算机科学理论的重要组成部分,也是实现高效、可靠的计算机程序设计的关键。本文将对编译原理的基本概念、发展历程、主要内容和实际应用进行详细介绍编译原理是计算机专业的一门核心课程,旨在介绍编译程序构造的一般原理和基本方法。编译原理不仅是计算机科学理论的重要组成部分,也是实现高效、可靠的计算机程序设计的关键。本文将对编译原理的基本概念、发展历程、主要内容和实际应用进行详细介绍编译原理是计算机专业的一门核心课程,旨在介绍编译程序构造的一般原理和基本方法。编译原理不仅是计算机科学理论的重要组成部分,也是实现高效、可靠的计算机程序设计的关键。本文将对编译原理的基本概念、发展历程、主要内容和实际应用进行详细介绍编译原理是计算机专业的一门核心课程,旨在介绍编译程序构造的一般原理和基本

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值