Java内存模型-Java内存模型的基础1

简介: 章节目录1.并发编程需要解决的问题-线程间通信&线程间同步2.Java内存模型的抽象结构3.从源代码到指令序列的重排序4.happens-before 简介1.

章节目录

  • 1.并发编程需要解决的问题-线程间通信&线程间同步
  • 2.Java内存模型的抽象结构
  • 3.从源代码到指令序列的重排序
  • 4.happens-before 简介

1.并发编程需要解决的问题-线程间通信&线程间同步

并发编程中需要处理两个关键问题:线程间通信、 线程间同步

线程之间通信机制分为两种:共享内存消息传递
共享内存通信与同步

操作类型 实现方式
通信 线程之间共享程序的公共状态,通过写-读内存中的变量的公共状态进行隐式通信
同步 显式进行同步,必须显式制定某个方法或某段代码需要在线程之间互斥执行

消息传递通信与同步

操作类型 实现方式
通信 线程之间没有公共状态,线程之间通过发送消息显式进行通信
同步 隐式进行同步,消息发送必须在消息发送之前

注意:java并发采用的是共享内存模型,java线程之间的通信总是隐式进行的。

2.Java内存模型的抽象结构

  • 在Java中所有的实例对象、静态数据域、和数组元素都存储在堆内存当中,堆内存在线程之间是共享的。 -堆中数据域是线程共享的
  • 局部变量、方法定义参数、和异常处理器参数不会在线程之间共享、他们不会有内存可见性问题,也不受内存模型的影响。-线程独享的

JMM简介
JMM决定一个线程对共享变量的写入何时对另一个线程可见。(可见性保证)
如下图所示:

img_d5ea21deb7dc4d01933818c3bc91fc28.png
JMM内存模型抽象结构示意图

图示解释

1.线程之间共享的变量存储在主内存中,每个线程都有一个本地内存,本地内
存中存储了用共享内存中共享数据的副本。

线程A与线程B之间进行通信

1.线程A把本地内存A中更新过的共享变量刷新到主存中去
2.线程B到主存中去读取线程A之前已更新过的新的共享变量

JMM通过控制主内存与每个线程的本地内存之间的交互,来为Java程序员提供内存可见性保证。

3.从源代码到指令序列的重排序

重排序的作用

在执行程序时,为了提高性能,编译器和处理器常常会对指令做重排序。
重排序类型 含义
编译器优化的重排序 编译器在不改变单线程程序语义的前提下,可以重新安排语句的执行顺序
指令级并行的重排序 不存在数据依赖性,处理器可以改变语句对应机器指令的执行顺序
内存系统的重排序 处理器采用缓存和读/写缓冲区,这使得加载和存储操作看起来是在乱序执行
对于处理器重排序,JMM处理器重排序规则要求java编译器在生成指令序列
时,插入特定类型的内存屏障指令,通过内存屏障指令禁止特定类型的处理器
重排序。

4.happens-before 简介

Java内存模型,使用happens-before的概念来阐述操作之间的内存可见性、
在JMM中,如果一个操作执行的结果需要对另一个操作可见、那么两个操作之间必须要存在happens-before(前一个操作的结果对后一个操作可见)关系。

与程序员密切相关的happens-before规则如下:

1.程序顺序规则:一个线程中的每个操作,happens-before于线程中的任意后续操作。
2.监视器锁规则:对一个锁的解锁,happens-before于随后对这个锁的加锁。
3.volatile规则:对一个volatile域的写,happens-before于任意后续对这个volatile域的读。
4.传递性:如果A操作happens-beforeB,且B happens-before C,那么A happens-before C。
目录
相关文章
|
14天前
|
存储 Java 编译器
Java内存区域详解
Java内存区域详解
29 0
Java内存区域详解
|
24天前
|
缓存 算法 Java
Java内存管理与调优:释放应用潜能的关键
【4月更文挑战第2天】Java内存管理关乎性能与稳定性。理解JVM内存结构,如堆和栈,是优化基础。内存泄漏是常见问题,需谨慎管理对象生命周期,并使用工具如VisualVM检测。有效字符串处理、选择合适数据结构和算法能提升效率。垃圾回收自动回收内存,但策略调整影响性能,如选择不同类型的垃圾回收器。其他优化包括调整堆大小、使用对象池和缓存。掌握这些技巧,开发者能优化应用,提升系统性能。
|
20天前
|
缓存 安全 Java
Java并发编程进阶:深入理解Java内存模型
【4月更文挑战第6天】Java内存模型(JMM)是多线程编程的关键,定义了线程间共享变量读写的规则,确保数据一致性和可见性。主要包括原子性、可见性和有序性三大特性。Happens-Before原则规定操作顺序,内存屏障和锁则保障这些原则的实施。理解JMM和相关机制对于编写线程安全、高性能的Java并发程序至关重要。
|
2天前
|
Java 程序员 数据库连接
Java从入门到精通:3.3.2性能优化与调优——内存管理篇
Java从入门到精通:3.3.2性能优化与调优——内存管理篇
Java从入门到精通:3.3.2性能优化与调优——内存管理篇
|
3天前
|
存储 安全 Java
滚雪球学Java(19):JavaSE中的内存管理:你所不知道的秘密
【4月更文挑战第8天】🏆本文收录于「滚雪球学Java」专栏,专业攻坚指数级提升,希望能够助你一臂之力,帮你早日登顶实现财富自由🚀;同时,欢迎大家关注&&收藏&&订阅!持续更新中,up!up!up!!
29 4
滚雪球学Java(19):JavaSE中的内存管理:你所不知道的秘密
|
10天前
|
存储 缓存 监控
Java内存管理:垃圾回收与内存泄漏
【4月更文挑战第16天】本文探讨了Java的内存管理机制,重点在于垃圾回收和内存泄漏。垃圾回收通过标记-清除过程回收无用对象,Java提供了多种GC类型,如Serial、Parallel、CMS和G1。内存泄漏导致内存无法释放,常见原因包括静态集合、监听器、内部类、未关闭资源和缓存。内存泄漏影响性能,可能导致应用崩溃。避免内存泄漏的策略包括代码审查、使用分析工具、合理设计和及时释放资源。理解这些原理对开发高性能Java应用至关重要。
|
18天前
|
存储 缓存 安全
【企业级理解】高效并发之Java内存模型
【企业级理解】高效并发之Java内存模型
|
24天前
|
搜索推荐 Java
Java基础(快速排序算法)
Java基础(快速排序算法)
24 4
|
25天前
|
Java
java中jar启动设置内存大小java -jar 设置堆栈内存大小
java中jar启动设置内存大小java -jar 设置堆栈内存大小
12 1
|
25天前
|
缓存 算法 Java
Java内存管理:优化性能和避免内存泄漏的关键技巧
综上所述,通过合适的数据结构选择、资源释放、对象复用、引用管理等技巧,可以优化Java程序的性能并避免内存泄漏问题。
27 5