Java 内存模型
转自WIKI,自由的百科全书
Java内存模型描述了在Java中,线程之间是如何通过内存互相通信、控制或者影响对方。内存模型和单线程模型共同构成了Java编程语言。
在1995年设计的Java内存模型被大多数人认为是不成功的,它使得许多可能改善性能的优化措施无法实施,也不能保证代码的绝对安全。在2004年,Tiger(Java 5.0)中,Java Community Process对内存模型进行了更新。
目录 |
背景
Java语言支持多线程应用的开发。但是线程间同步的技术难度常常让开发者们望而却步。Java应用对各种处理器和操作系统的支持使得这个问题更为严重。为了能够界定软件的行为,Java的设计者们决定所有Java应用的行为必须可以清楚地被定义。
现代地高级语言开发中,代码常常不是按照编写顺序来执行的。编译器、处理器和内存调度系统会对代码重新排序来实现最佳的性能。在多处理器框架下,每个处理器都有自己的缓存,而且这些缓存与主内存之间并不是同步的。在这种情况下,如果从性能的角度考虑,要求线程之间保持完美的同步并不是一个好主意。因为这将带来大量的性能开销。这意味着在某些时候,不同的线程在同一块共享数据上,可能会看到完全不同的值。
在单线程应用中,推断代码的执行是很容易的。典型的情况是,系统会为每个线程在独立的环境中建立类似as-if-serial语义块。当一个线程被执行的时候,至少看上去这个线程的所有行为是按照他们在代码中的编写顺序执行的。即使这些行为并不真的是按照这个顺序发生。
如果一个线程不按顺序执行它的指令,那么其他线程的指令执行有可能也不是按照他原来的顺序。即使后一个线程并不涉及前一个线程的语句块。
例如:如果有两个线程并发的执行下列指令。
Thread 1 |
Thread 2 |
x = 1; |
int r1 = y; |
y = 1; |
int r2 = x; |
如果没有重新排序,Thread2对y的读取返回1,那么顺后对x的读取也会返回1,因为对x的写入操作发生在对y的写入操作之前。然而,如果这两个写入被重新排序,那么即使对y的读取返回1,对x的读取也可能返回0。
Java内存模型定义了多线程程序的正当行为(allowable behavior),和什么情况下有可能对指令代码重新排序。它设置了线程和主内存之间的运行期约束(execution-time constraints), 来保证Java应用程序的稳定和可靠。这就是使得在多线程环境下仍然可以合理的推断代码的执行情况,即使代码已经被动态编译器,CPU和内存调度系统进行了优化。
内存模型
在单线程的情况下,这个规则很简单。
Java语言规范要求JVM去观察within-thread as-if-serial语句块。运行环境(在这种情况下,通常是指动态编译器,CPU和内存调度系统)可以自由的采用一些对代码执行的优化(调整执行顺序),只要能保证这个孤立的线程的执行结果与完全按照他的代码编写顺序执行的结果完全相同。
在这里要注意的是,as-if-serial语句块不能防止不同的线程看到的同一数据有不同的值。内存模型对于这个问题(当数据被读取时什么样的返回值是合法的)是有明确定义的。
相关推荐
Java内存模型,简称JMM(Java Memory Model),是Java编程语言规范的一部分,它定义了程序中各个线程如何访问和修改共享变量,以及如何确保数据的一致性。深入理解Java内存模型对于编写高效的并发程序至关重要。本文...
Java内存模型是并发编程中一个至关重要的概念,它定义了共享变量的访问规则,以及这些变量如何在多线程环境下进行读写操作。在深入理解Java内存模型之前,我们需要先了解并发编程模型的分类,然后掌握Java内存模型的...
Java程序员了解CPU以及相关的内存模型,对于深入理解Java内存模型以及并发编程至关重要。CPU作为计算机硬件的核心,其架构和工作原理影响着软件的性能和执行效率。尤其在Java这种多线程、高并发的编程语言中,对CPU...
### Java内存模型的历史变迁 #### 一、引言 随着多核处理器的普及与高性能计算需求的增长,Java作为主流编程语言之一,对于并发处理的支持变得越来越重要。Java内存模型(Java Memory Model,简称JMM)作为Java...
Java内存模型,简称JMM(Java Memory Model),是Java编程语言规范的一部分,它定义了线程如何共享和访问内存,以及在多线程环境中如何保证数据一致性。理解JMM对于编写高效、正确且线程安全的Java代码至关重要。 ...
Java内存模型(JVM Memory Model,简称JMM)是Java平台中的一个重要概念,它定义了程序中各个变量的访问规则,以及在多线程环境下的内存一致性效果。JMM主要解决的是并发环境下不同线程之间如何共享数据以及如何保证...
这些文档如"Java内存模型.docx"、"Java内存模型2.docx"、"深入Java核心 Java内存分配原理精讲.docx"、"java内存模型.pdf"将深入探讨这些概念,帮助开发者更深入地理解Java内存模型及其在实际编程中的应用。...
Java内存模型详解JMM Java内存模型(Java Memory Model,JMM)是Java虚拟机(JVM)中的一种内存模型,它描述了程序中各个变量之间的关系,以及在实际计算机系统中将变量存储到内存和从内存中取出变量这样的底层细节...
java 内存模型 java 内存模型 java 内存模型 java 内存模型
Java 内存模型的抽象 4 重排序 6 处理器重排序与内存屏障指令 7 happens-before 10 重排序 13 数据依赖性 13 as-if-serial 语义 13 程序顺序规则 15 重排序对多线程的影响 15 顺序一致性 19 数据竞争与顺序...
Java内存模型(Java Memory Model,简称JMM)是Java虚拟机(JVM)规范中定义的一种内存模型,它涉及了线程之间共享变量的可见性问题。在并发编程中,理解Java内存模型对于编写正确的多线程程序至关重要。 首先,...
Java内存模型(Java Memory Model,JMM)是Java平台中非常关键的概念,它定义了线程如何共享和访问内存中的数据,以及在多线程环境下如何保证数据的一致性。这本书"深入理解Java内存模型"显然是为了帮助读者深入探讨...
### Java内存模型详解 #### 1. JMM简介 ##### i. 内存模型概述 Java内存模型(Java Memory Model, JMM)是Java虚拟机(JVM)的一部分,用于规定程序中的各种变量(包括实例字段、静态字段和数组元素等)在多个...
Java内存模型(JMM)是Java虚拟机(JVM)的一部分,它定义了程序中不同变量如何交互,特别是在多线程环境下。JMM确保了在各种硬件和操作系统平台上,Java程序的行为具有一致性和可预测性。Java内存模型的主要目标是...
Java内存模型(Java Memory Model,JMM)是Java虚拟机(JVM)规范中的一个重要组成部分,它定义了程序中各个变量(包括实例域、静态域和数组元素)的访问规则,以及在实际计算机系统中如何将这些变量存储在内存和从...
Java 内存模型(Java Memory Model,简称 JMM)是 Java 平台中关于线程如何访问共享变量的一套规则,它定义了线程之间的内存可见性、数据一致性以及指令重排序等关键概念,对于多线程编程和并发性能优化至关重要。...
Java线程之间的通信由Java内存模型(本文简称为JMM)控制,JMM决定一个线程对共享变量的写入何时对另一个线程可见。从抽象的角度来看,JMM定义了线程和主内存之间的抽象关系:线程之间的共享变量存储在主内存(main ...