Java内存结构
Java代码运行在JVM上,JVM将所管理的内存划分为不同的数据区域
上图是Java虚拟机规范,不同的虚拟机实现会各有不同,但是一般会遵守规则。
上图划分的是逻辑区域,并不是绝对意义上的物理区域,因为某些版本的jdk中方法区其实是在堆中实现的。
Java内存模型
Java堆和方法区的区域是多个线程共享的数据区域;也就是说,多个线程可能操作保存在堆或方法区中的同一个数据。(Java线程间通过共享内存进行通信)
Java多线程之间通过共享内存进行通信;由于采用共享内存进行通信,在通信过程中会存在一系列如原子性,可见性,顺序性等问题,而jvm是JMM(Java内存模型)是围绕着多线程通信以及与其相关的一系列特性而建立的模型。volatile、synchronized
Java对象模型
Java是面向对象语言,Java对象在jvm中存储也是有一定结构的。java对象自身的存储模型称之为Java对象模型。
每一个Java类,在被JVM加载的时候,JVM会给这个类创建一个instanceKlass
,保存在方法区,用来在JVM层表示该Java类。当我们在Java代码中,使用new创建一个对象的时候,JVM会创建一个instanceOopDesc
对象,这个对象中包含了对象头以及实例数据。