Java内存模式以及volatile关键字的使用

简介: Java内存模式以及volatile关键字的使用

1.Java内存模型

(1)Java 内存模型(Java Memory Model,简称 JMM),它是一个抽象的概念,JMM是和多线程相关的,它是一组规范,描述了一组规则,定义了多线程对共享变量读写操作时的行为规范,通过这些规则来规范对内存的读写操作,从而保证多线程对共享数据操作的原子性、可见性以及有序性。

(2)同时通过这套规范,屏蔽掉底层不同操作系统、不同 CPU 硬件之间的差异,让 Java 程序员按照统一的方式来编程,保证 Java 程序在各种平台下对内存的访问都能够得到相同的效果

(3)具体如下:

①所有的变量都存储在主内存中,每个线程都可以访问;

②每条线程都有自己私有的工作内存;

③线程的工作内存中保存了该线程中用到的主内存变量的副本拷贝;

④线程对变量的所有操作都必须在工作内存中进行,而不能直接操作主内存;

⑤不同线程之间也无法直接访问对方工作内存中的变量

2.volatile

(1)volatile关键字只能修饰类变量和实例变量,对于方法参数、局部变量以及实例常量、类常量都不能进行修饰;

(2)volatile 的主要作用是使共享变量在多线程间可见,如果一个字段被声明成 volatile,Java 线程内存模型会确保所有线程看到这个变量的值都是一致的

(3)volatile 可以保证可见性,不能保证原子性,volatile 也可以保证有序性

2.1 volatile 的使用场景

(1)在一些对变量的操作已经是原子性的情况下,可以使用 volatile 关键字;

(2)运行结果并不依赖变量的当前值,可以使用 volatile 关键字,volatile 不适合复合操

作,像 i++这种类型操作不适合使用 volatile; int a=10; a = 20;

(3)一些状态标志的场景,比如仅仅是使用一个布尔状态 true 和 false 标志;

(4)定期更新,供程序内部使用的变量,可以使用 volatile;

(5)双重检查锁定(double-checked-locking)问题可以用 volatile;

注:如果对共享变量已经加锁,加锁本身已经保证了可见性、原子性、有序性,此时就没必要再使用 volatitle

相关文章
JVM简介—1.Java内存区域
本文详细介绍了Java虚拟机运行时数据区的各个方面,包括其定义、类型(如程序计数器、Java虚拟机栈、本地方法栈、Java堆、方法区和直接内存)及其作用。文中还探讨了各版本内存区域的变化、直接内存的使用、从线程角度分析Java内存区域、堆与栈的区别、对象创建步骤、对象内存布局及访问定位,并通过实例说明了常见内存溢出问题的原因和表现形式。这些内容帮助开发者深入理解Java内存管理机制,优化应用程序性能并解决潜在的内存问题。
JVM简介—1.Java内存区域
|
18天前
|
Volatile关键字与Java原子性的迷宫之旅
通过合理使用 `volatile`和原子操作,可以在提升程序性能的同时,确保程序的正确性和线程安全性。希望本文能帮助您更好地理解和应用这些并发编程中的关键概念。
40 21
课时8:Java程序基本概念(标识符与关键字)
课时8介绍Java程序中的标识符与关键字。标识符由字母、数字、下划线和美元符号组成,不能以数字开头且不能使用Java保留字。建议使用有意义的命名,如student_name、age。关键字是特殊标记,如蓝色字体所示。未使用的关键字有goto、const;特殊单词null、true、false不算关键字。JDK1.4后新增assert,JDK1.5后新增enum。
|
15天前
|
java设置栈内存大小
在Java应用中合理设置栈内存大小是确保程序稳定性和性能的重要措施。通过JVM参数 `-Xss`,可以灵活调整栈内存大小,以适应不同的应用场景。本文介绍了设置栈内存大小的方法、应用场景和注意事项,希望能帮助开发者更好地管理Java应用的内存资源。
29 4
【YashanDB 知识库】kettle 同步大表提示 java 内存溢出
【问题分类】数据导入导出 【关键字】数据同步,kettle,数据迁移,java 内存溢出 【问题描述】kettle 同步大表提示 ERROR:could not create the java virtual machine! 【问题原因分析】java 内存溢出 【解决/规避方法】 ①增加 JVM 的堆内存大小。编辑 Spoon.bat,增加堆大小到 2GB,如: if "%PENTAHO_DI_JAVA_OPTIONS%"=="" set PENTAHO_DI_JAVA_OPTIONS="-Xms512m" "-Xmx512m" "-XX:MaxPermSize=256m" "-
Java中的this关键字详解:深入理解与应用
本文深入解析了Java中`this`关键字的多种用法
209 9
Java 并发编程——volatile 关键字解析
本文介绍了Java线程中的`volatile`关键字及其与`synchronized`锁的区别。`volatile`保证了变量的可见性和一定的有序性,但不能保证原子性。它通过内存屏障实现,避免指令重排序,确保线程间数据一致。相比`synchronized`,`volatile`性能更优,适用于简单状态标记和某些特定场景,如单例模式中的双重检查锁定。文中还解释了Java内存模型的基本概念,包括主内存、工作内存及并发编程中的原子性、可见性和有序性。
Java 并发编程——volatile 关键字解析
利用 Java 代码获取淘宝关键字 API 接口
在数字化商业时代,精准把握市场动态与消费者需求是企业成功的关键。淘宝作为中国最大的电商平台之一,其海量数据中蕴含丰富的商业洞察。本文介绍如何通过Java代码高效、合规地获取淘宝关键字API接口数据,帮助商家优化产品布局、制定营销策略。主要内容包括: 1. **淘宝关键字API的价值**:洞察用户需求、优化产品标题与详情、制定营销策略。 2. **获取API接口的步骤**:注册账号、申请权限、搭建Java开发环境、编写调用代码、解析响应数据。 3. **注意事项**:遵守法律法规与平台规则,处理API调用限制。 通过这些步骤,商家可以在激烈的市场竞争中脱颖而出。
|
3月前
|
Java volatile关键字:你真的懂了吗?
`volatile` 是 Java 中的轻量级同步机制,主要用于保证多线程环境下共享变量的可见性和防止指令重排。它确保一个线程对 `volatile` 变量的修改能立即被其他线程看到,但不能保证原子性。典型应用场景包括状态标记、双重检查锁定和安全发布对象等。`volatile` 适用于布尔型、字节型等简单类型及引用类型,不适用于 `long` 和 `double` 类型。与 `synchronized` 不同,`volatile` 不提供互斥性,因此在需要互斥的场景下不能替代 `synchronized`。
2411 3
《volatile使用与学习总结:》多层面分析学习java关键字--volatile
《volatile使用与学习总结:》多层面分析学习java关键字--volatile
52 0

热门文章

最新文章

AI助理

你好,我是AI助理

可以解答问题、推荐解决方案等