时间:2021-05-19
jvm虚拟机在运行时需要用到的内存区域.广泛一点就是堆和栈,其实不然,堆和栈只是相对比较笼统的说法,真正区分有如下几个先上图一:
总的就是
java的内存模型
内存模型又分堆内存(heap)和方法区(有时也称为non-heap)和栈
堆又分新生代(Young)和老年代(old/Tenured)
新生代又分默认比例为8:1:1的eden空间、from survivor空间、to survivor空间
当进行垃圾回收时,eden、survivor from 存活得对象会复制到servivor to空间
接着from与to空间互换.(当from区的对象足够老时,即标记的次数达到老年级别,便到老年代去)
内存的大小设置参数可以如下一张图说明
-XMS:堆的最小空间
-XMX:堆的最大空间
-PermSize:方法区的最小空间
-MaxPermSize:方法区的最大空间
-Xss:每个线程的堆栈空间
-newSize:新生代最小空间
-maxNewSize:新生代最大空间
老年代内存可以通过设置堆的大写和新生代的大小来控制
老年代内存=堆内存-新生代内存
栈
程序计数器
线程私有,控制着字节码所执行的行数.调用本地方法(native)时为空
当前线程所执行的字节码的行号指示器,字节码解释器就是在工作时通过改变计数器的行号来获获取要执行的字节码指令.调用本地方法(native)时计数器为空
虚拟机栈
线程私有,java执行方法的内存模型
每个方法执行的时候都会创建一个栈帧,用于存放局部变量、操作数栈、动态链接、方法出口等信息
局部变量表:基本数据类型、对象引用、long和double类型占两个局部变量空间
每调用一个方法,都会对参数进行压栈
本地方法栈
线程私有.调用native方法时
堆:
堆内存
线程共享,对象的实例以及数组都存储在这里
堆又分新生代、老年代
在分代收集算法中,新生代又分eden空间、from survitor空间 和to survitor空间).它们之间内存比例为8:1:1
方法区
线程共享
存放类的信息、常量、静态变量、即时编译后的代码
方法区下又有运行时常量池:存放编译期生成的字面量和符号引用
以上这篇基于jvm java内存区域的介绍就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持。
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
java语言,开发者不能直接控制程序运行内存,对象的创建都是由类加载器一步步解析,执行与生成与内存区域中的;并且jvm有自己的垃圾回收器对内存区域管理,回收;但
JVM是一种抽象的计算机,基于堆栈架构,它有自己的指令集和内存管理,是Java跨平台的依据,JVM解释执行字节码,或将字节码编译成本地代码执行。Java虚拟机体
Scala的环境搭建由于scala是基于java来开发的,编写的java类可以使用javac命令编译成.class文件被JVM加载到内存中执行!那么scala可
一,jvm内存区域1,程序计数器一块很小的内存空间,作用是当前线程所执行的字节码的行号指示器。2,java栈与程序计数器一样,java栈(虚拟机栈)也是线程私有
浅谈java内存模型不同的平台,内存模型是不一样的,但是jvm的内存模型规范是统一的。其实java的多线程并发问题最终都会反映在java的内存模型上,所谓线程安