内容简介:java内存模型是符合内存模型的一种规范
为了保证共享内存的正确性(可见性、有序性、原子性),内存模型定义了共享内存系统中多线程程序读写操作行为的规范。
通过这些规则来规范对内存的读写操作,从而保证指令执行的正确性。它与处理器有关、与缓存有关、与并发有关、与编译器也有关。他解决了CPU多级缓存、处理器优化、指令重排等导致的内存访问问题,保证了并发场景下的一致性、原子性和有序性。
java 内存模型
java内存模型是符合内存模型的一种规范
JMM是一种规范,目的是解决由于多线程通过共享内存进行通信时,存在的本地内存数据不一致、编译器会对代码指令重 排序 、处理器会对代码乱序执行等带来的问题。
- 主内存: 计算机的物理内存 memory
- 工作内存: 每一条线程都拥有自己的工作内存,用于保存用到的变量的主内存复本拷贝。每个线程对数据的操作,都是在工作内存中进行,不会读写主内存。
Java内存模型,除了定义了一套规范,还提供了一系列原语,封装了底层实现后,供开发者直接使用。包括synchronized和volatile等
synchronized
- 当synchronized作用于普通方法是,锁对象是this;
- 当synchronized作用于静态方法是,锁对象是当前类的Class对象;
- 当synchronized作用于代码块时,锁对象是synchronized(obj)中的这个obj。
对于同步方法,JVM采用 ACC_SYNCHRONIZED
标记符来实现同步。 对于同步代码块。JVM采用 monitorenter
、 monitorexit
两个指令来实现同步。
-
实现原子性:
通过monitorenter
和monitorexit
指令,可以保证被synchronized
修饰的代码在同一时间只能被一个线程访问,在锁未释放之前,无法被其他线程访问到。因此,在 Java 中可以使用synchronized
来保证方法和代码块内的操作是原子性的。当monitorenter
后如果线程的时间片到了
,因为锁没有释放,所以别的线程还是不会中途插入执行当前代码,等重新轮到时间片,利用synchronized
的可重入性,本线程还是可以继续执行,实现原子性。 -
可见性(
仅对synchronized锁定对象保证可见性
)
被synchronized修饰的代码,在开始执行时会加锁,执行完成后会进行解锁。而为了保证可见性,有一条规则是这样的:对一个变量解锁之前,必须先把此变量同步回主存中。这样解锁后,后续线程就可以访问到被修改后的值。
所以,synchronized关键字锁住的对象,其值是具有可见性的 -
有序性
重排序的前提是保证单线程执行结果不能被改变,synchronized
修饰的方法或者代码块在同一时间段内只有一个线程能访问,所以可以保证执行结果不变。
以上所述就是小编给大家介绍的《jvm的内存模型》,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对 码农网 的支持!
猜你喜欢:- JVM内存模型 与 JMM内存模型
- C++11 中的内存模型(上):内存模型基础
- C++11 中的内存模型(下):C++11 支持的几种内存模型
- JVM内存模型解析
- golang内存模型
- 并发编程:内存模型
本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们。
软件开发者路线图
Dave H. Hoover、Adewale Oshineye / 王江平 / 机械工业出版社 / 2010年9月 / 35.00元
作为一名软件开发者,你在奋力推进自己的职业生涯吗?面对今天日新月异和不断拓展的技术,取得成功需要的不仅仅是技术专长。为了增强专业性,你还需要一些软技能以及高效的学习技能。本书的全部内容都是关于如何修炼这些技能的。两位作者Dave Hoover和Adewale Oshineye给出了数十种行为模式,来帮你提高主要的技能。 本书中的模式凝结了多年的调查研究、无数次的访谈以及来自O’Reilly在......一起来看看 《软件开发者路线图》 这本书的介绍吧!