Java并发编程中的内存模型是什么

发布时间:2021-11-23 08:52:53 作者:iii
来源:亿速云 阅读:442

这篇文章主要介绍“Java并发编程中的内存模型是什么”,在日常操作中,相信很多人在Java并发编程中的内存模型是什么问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”Java并发编程中的内存模型是什么”的疑惑有所帮助!接下来,请跟着小编一起来学习吧!

1、什么是Java的内存模型

Java内存模型简称JMM(Java Memory Model),JMM是和多线程并发相关的一组规范。各个jvm实现都要遵循这个JMM规范。才能保证Java代码在不同虚拟机顺利运行。因此,JMM 与处理器、缓存、并发、编译器有关。它解决了CPU 多级缓存、处理器优化、指令重排等导致的结果不可预期的问题。

Java并发编程中的内存模型是什么

2、为什么需要Java内存模型

程序的运行结果依赖于处理器,而不同的处理器规则都不一样,不同处理器差异是很大的,所以同段代码在处理器A运行正常,搬到处理器B运行结果是不一样的,所以为了兼容这种差异,推出了Java内存模型规范,JMM是一个规范标准,JMM保证了不同处理器的处理结果一致,同时也保证不同编译器、jvm等等的一致性。所以就保证了Java语言“书写一次、到处运行”

3、Java内存模型及操作规范

1.共享变量都是放在主内存中的

2.每个线程都有自己的工作内存,线程只可操作自己的工作内存

3.线程要操作共享变量,需要从主内存中读取到工作内存,改变值之后要从工作内存同步到主内存

Java并发编程中的内存模型是什么

4、Java内存模型规定的原子操作

Java内存模型的同步交换协议,规定了8种原子操作

原子操作:不可被中断的一个或一系列操作

Java内存模型的同步交互协议,执行上述8种原子操作时必须满足如下规则

不允许read和load,store和write操作之一单独出现。即不允许加载或同步工作到一半。

不允许一个线程丢弃它最近的assign操作,即变量在工作内存中改变之后,必须将数据同步回主内存

不允许一个线程无原因地(无assign操作)将数据从工作内存同步到主内存中。

一个新的变量可能在主内存中诞生。

一个变量在同一个时刻只允许一条线程对其进行lock操作,但lock操作可以被同一条线程重复执行多次,多次lock之后必须要执行相同次数unlock操作,变量才会解锁

如果对一个对象进行lock操作,那么会清空工作内存变量中的值,在执行引擎使用这个变量前,需要重新执行load或assign操作初始变量的值

如果一个对象事先没有被lock,就不允许对其进行unlock操作,也不允许去unlock一个被其他线程锁住的变量。

对一个变量执行unlock操作之前,必须将此变量同步回主内存中(执行store、write)

5、Java内存模型同步协议

Java内存模型的同步协议,操作规范 将一个变量从主内存复制到工作内存要顺序执行read、load操作;要将变量从工作内存同步回主内存要用store、write操作。只要求顺序执行,不一定是连续执行

图引用网上资料:

Java并发编程中的内存模型是什么

6、Java内存模型的HB法则

并发编程有三个重要特效:原子行可见性有序性

在说JMM的happens-before(HB)法则之前,先说说并发编程的有序性。说到并发线程的有序性,还需要涉及到指令重排序

假如我们写一个程序,我们会期待这些语句的实际执行顺便和代码的顺序是一致的,大部分情况是一致的,但实际上,编译器、JVM 或者 CPU 都有可能出于优化等目的,对执行的顺序进行调整,这个就是指令重排序

代码顺序如图:

Java并发编程中的内存模型是什么

指令重排后,a=100; a= a+100会提到一起执行,效率提高

Java并发编程中的内存模型是什么

上面的例子,是可以提高执行效率,但是有时候指令重排是会导致问题的,如下代码例子,代码顺序是先初始化content,然后设置标识为true,线程B检测到为true之后,调用content的方法

Java并发编程中的内存模型是什么

如果指令重排后,这种情况就会出现没初始化完成,就直接调用conten的方法

Java并发编程中的内存模型是什么

所以,指令重排有好处也有坏处,一般可能是cpu、编译器或者是内存会进行指令重排,为了避免指令重排,保证并发编程的有序性,有时候需要使用synchronized等锁或者volatile等等方式避免

1.JMM规定了happens-before(先行发生)原则,来保证很多操作的有序性。

2.当我们代码操作不满足先行发生原则时,则需在编码时使用volatile、synchronized来保证有序性

JMM的HB法则

到此,关于“Java并发编程中的内存模型是什么”的学习就结束了,希望能够解决大家的疑惑。理论与实践的搭配能更好的帮助大家学习,快去试试吧!若想继续学习更多相关知识,请继续关注亿速云网站,小编会继续努力为大家带来更多实用的文章!

推荐阅读:
  1. Redis的内存模型是什么
  2. Java中的内存模型

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

java

上一篇:Vue+ElementUI怎么处理超大表单

下一篇:c语言怎么实现含递归清场版扫雷游戏

相关阅读

您好,登录后才能下订单哦!

密码登录
登录注册
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》