内容简介: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的内存模型》,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对 码农网 的支持!
本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们。
RESTful Web Services Cookbook
Subbu Allamaraju / Yahoo Press / 2010-3-11 / USD 39.99
While the REST design philosophy has captured the imagination of web and enterprise developers alike, using this approach to develop real web services is no picnic. This cookbook includes more than 10......一起来看看 《RESTful Web Services Cookbook》 这本书的介绍吧!