02java内存模型

YL10000      2022-05-29     810

关键词:

java内存模型

1、JVM内存区域

  • 方法区:类信息、常量、static、JIT (信息共享)
  • java堆:实例对象 GC (信息共享) OOM
  • VM stack:JAVA方法在运行的内存模型 (OOM)
  • PC: java线程的私有数据,这个数据就是执行下一条指令的地址
  • Native method stack: 月JVM的native

2、java内存模型(JMM 规范、抽象的模型)

  • 主内存:共享的信息
  • 工作内存:私有信息、基本数据类型,直接分配到主内存,引用的地址放在工作内存中,引用的对象放在堆中
  • 工作方式:
    • 线程修改私有数据,直接在工作内存修改
    • 线程修改共享数据,把数据复制到工作空间中,在工作空间中修改,修改完之后,刷新到主内存中

3、 硬件内存架构月java内存模型

cpu缓存的一致性问题:并发处理的不同步
解决方法:
- 总线加锁 降低了CPU的吞吐量
- 缓存上的一致性协议(MESI)<br>
    当cpu在cache中操作数据时,如果该数据是共享变量,数据在cache读到寄存器中,进行新修改,并更新内存数据<br>
    cache line值无效,其他的cpu就从内存中读数据

4、 并发编程的三个重要特征

原子性、可见性和有序性

  • 原子性保证方式:
    • synchronized
    • JUC Lock的lock
  • 可见性
    • volatile:在JMM模型上实现MESI协议
    • synchronized:加锁
    • JUC Lock的lock
  • 有序性
    • Volatile禁止重排序
    • synchronized
    • happens-before原则
      • 程序次序原则
      • 锁定原则:后一次加锁必须等前一次解锁
      • Volatile原则:霸道原则
      • 传递原则:A--B--C A--C

java内存模型知识归纳

文章目录前言java内存模型知识归纳01java内存模型02JVM栈的构成前言  如果您觉得有用的话,记得给博主点个赞,评论,收藏一键三连啊,写作不易啊^_^。  而且听说点赞的人每天的运气都不会太差,实在... 查看详情

java虚拟机详解02----jvm内存结构(代码片段)

主要内容如下:JVM启动流程JVM基本结构内存模型编译和解释运行的概念 一、JVM启动流程:JVM启动时,是由java命令/javaw命令来启动的。二、JVM基本结构:JVM基本结构图:《深入理解Java虚拟机(第二版)》中的描述是下面这个... 查看详情

java内存模型

Java内存模型规范了Java虚拟机与计算机内存是如何协同工作的。Java虚拟机是一个完整的计算机的一个模型,因此这个模型自然也包含一个内存模型——又称为Java内存模型。如果你想设计表现良好的并发程序,理解Java内存... 查看详情

并发艺术--java内存模型

前言  本章大致分为四部分。java内存模型的基础,介绍内存模型的相关基本概念;java内存模型中的顺序一致性,主要介绍重排序和顺序一致性;同步原语,涉及synchronized,volatile,final三个同步原语的内存含义及重排序等;jav... 查看详情

java内存模型

Java内存模型Java虚拟机规范中试图定义一种Java内存模型来屏蔽掉各种硬件和操作系统的内存访问差异,以实现让Java程序在各种平台下都能达到一致的内存访问效果。Java内存模型的主要目标是定义程序中各个变量的访问规则,即... 查看详情

深入理解计算机系统02isa与内存模型

...2位x86架构的名称x86-32改称为IA-32,一种身边很常见的ISA【内存模型】【过程调用】 •ISA(InstructionSetArchitecture)位于软件和硬件之间•硬件的功能通过ISA提供出来•软件通过IS 查看详情

java内存模型

1.java内存模型是什么?java内存模型即JavaMemoryModel,简称JMM,其规范了Java虚拟机与计算机内存时如何协同工作的,规定了一个线程如何和何时看到其他线程修改过的值,以及在必须时,如何同步访问共享变量。    2... 查看详情

java内存模型

Java虚拟机规范试图定义一种Java内存模型来屏蔽掉各种硬件和操作系统的内存访问差异,以实现让Java程序在各种平台下都能达到一致的并发效果。在JDK1.5发布后,Java的内存模型已经成熟和完善起来了。1.主内存与工作内存:Java... 查看详情

第三章java内存模型(上)

 本章大致分为4部分:Java内存模型的基础:主要介绍内存模型相关的基本概念Java内存模型中的顺序一致性:主要介绍重排序和顺序一致性内存模型同步原语:主要介绍3个同步原语(synchroized、volatile和final)的内存语义及重... 查看详情

java内存模型的历史变迁

本文通过介绍Java的新/旧内存模型,来展示Java技术的历史变迁。旧的Java内存模型Java使用的是共享内存的并发模型,在线程之间共享变量。Java语言定义了线程模型规范,通过内存模型控制线程与变量的交互,从而实现Java线程之... 查看详情

java内存模型

声明:转载自茶轴的青春的博客??网上有很多关于Java内存模型的文章,在《深入理解Java虚拟机》和《Java并发编程的艺术》等书中也都有关于这个知识点的介绍。但是,很多人读完之后还是搞不清楚,甚至有的人说自己更懵了。... 查看详情

java内存模型(代码片段)

1、简介    Java内存模型规范了Java虚拟机与计算机内存是如何协同工作的。Java虚拟机是一个完整的计算机的一个模型,因此这个模型自然也包含一个内存模型——又称为Java内存模型。    如果你想设计表现良好的并发程... 查看详情

jvm内存模型

转自:http://gityuan.com/2016/01/09/java-memory/#section一、内存模型Java内存模型,往往是指Java程序在运行时内存的模型,而Java代码是运行在Java虚拟机之上的,由Java虚拟机通过解释执行(解释器)或编译执行(即时编译器)来完成,故Java内存... 查看详情

来,了解一下java内存模型(jmm)

网上有很多关于Java内存模型的文章,在《深入理解Java虚拟机》和《Java并发编程的艺术》等书中也都有关于这个知识点的介绍。但是,很多人读完之后还是搞不清楚,甚至有的人说自己更懵了。本文,就来整体的介绍一下Java内... 查看详情

java内存模型(代码片段)

Java内存模型Java内存模型硬件内存模型多CUP缓存产生的同步问题CPU指令重排Java内存模型线程通信中可能存在的问题并发三要素可见性原子性有序性Java内存模型参考视频:https://www.bilibili.com/video/BV1F64y1B7sV参考博客:https://z... 查看详情

java内存模型(代码片段)

Java内存模型Java内存模型硬件内存模型多CUP缓存产生的同步问题CPU指令重排Java内存模型线程通信中可能存在的问题并发三要素可见性原子性有序性Java内存模型参考视频:https://www.bilibili.com/video/BV1F64y1B7sV参考博客:https://z... 查看详情

java内存模型

为何需要java内存模型(JavaMemoryModel,JMM):  用于屏蔽各种操作系统和硬件之间的内存访问差异,使得java能够在各种平台下能够达到一致的运行结果。java内存模型(虚拟机内存):  1、主内存:所有的变量都存储在主内存... 查看详情

全面理解java内存模型

Java内存模型即JavaMemoryModel,简称JMM。JMM定义了Java虚拟机(JVM)在计算机内存(RAM)中的工作方式。JVM是整个计算机虚拟模型,所以JMM是隶属于JVM的。如果我们要想深入了解Java并发编程,就要先理解好Java内存模型。Java内存模型定义了... 查看详情