JMM模型

1.JMM介绍:
	java memory model,java内存模型
2.JMM内存模型的组成:
主内存(共享内存):
* heap堆: 存放所有对象的实例;堆不存放对象引用和基本数据类型,只存放对象实例本身
* method area方法区(也叫静态区): 方法区存放Class类对象以及一些static,final变量;方法区的数据都是唯一的,常量池也在方法区中
工作内存(线程私有内存,每个线程对应一个工作内存):
* program counter register(程序计数器): 每个线程都有一个程序计数器,代表当前线程的字节码行号指示器,比如cpu切换时需要用程序计数器来完成
* Java Virtual Machine Stacks(虚拟机栈): java方法执行的内存模型,每次有方法进栈执行,都会创建一个栈桢,来保存方法中的所有变量;栈桢保存基本数据类型是保存具体的值,保存引用数据类型保存主内存引用;当方法真正需要用到引用数据类型的变量值,就会去主内存中读取变量副本到栈桢,操作完毕后,再更新回主内存
* native method stacks(本地方法栈): 类似于虚拟机栈,但是本地方法栈是指使用java调用操作系统语言(C,C++)的方法,通常不需要我们关心
3.JMM线程通信:
* 共享变量:
	每一个线程的工作内存(程序计数器,虚拟机栈,本地方法栈)都会从主内存(方法区,)中保存一份它所需要用到的变量的副本,当它对变量操作完毕后,就会将修改后的数据更新到主内存中(存在并发问题)
* 消息传递: wait()/notify()
4.Java内存模型与硬件内存架构的关系:
硬件内存架构分为:cpu寄存器(存储数据),cpu缓存区(缓存数据),cpu主内存(从硬件架构的角度看,主内存的数据来源于整个jvm,即jvm的主内存和工作内存都是硬件架构的主内存);
	Java中的线程实际上是一个轻量级的进程lwp(light weight process),jvm将lwp映射为操作系统cpu的内核线程来处理数据;cpu内存线程处理cpu寄存器的数据,而cpu寄存器的数据优先从cpu缓存中获取(也叫缓存命中率),如果cpu缓存没有,再从主内存获取数据 

在这里插入图片描述

  • 2
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值